Skip to content

xmutex.h tweaks

xmutex.h tweaks #381

Workflow file for this run

name: API documentation
permissions:
contents: write
pull-requests: write
on:
release:
types: [published]
push:
branches:
- main
paths:
- 'src/**'
- 'include/**'
- 'css/**'
- 'resources/**'
- 'Doxyfile'
- '*.md'
- '.github/workflows/dox.yml'
pull_request:
paths:
- 'src/**'
- 'include/**'
- 'css/**'
- 'resources/**'
- 'Doxyfile'
- '*.md'
- '.github/workflows/dox.yml'
jobs:
apidocs:
name: Generate API documentation
runs-on: ubuntu-latest
steps:
- name: install doxygen
run: sudo apt-get install doxygen
- uses: actions/checkout@v6
- name: Generate docs
run: make dox
site-update:
name: Update github pages
needs: apidocs
if: github.repository_owner == 'Sigmyne' && (github.event_name == 'release' || contains(github.event.head_commit.message, 'site update'))
runs-on: ubuntu-latest
steps:
- name: Checkout source
uses: actions/checkout@v6
- name: Generate headless README
run: make -C doc README.md
- uses: mattnotmitt/doxygen-action@edge
with:
working-directory: 'doc'
additional-packages: font-roboto
- name: Insert Google analytics tracker
run: for file in doc/html/*.html ; do sudo sed -i "/<\/head>/e cat resources/analytics.html" $file ; done
- name: Checkout gh-pages
uses: actions/checkout@v6
with:
ref: 'gh-pages'
path: site
- name: Assert doc folder
run: mkdir -p site/doc
- name: Copy markdown documentation
run: cp -a doc/*.md site/doc/
- name: Copy HTML documentation
run: cp -a doc/html site/apidoc/
- name: Copy CHANGELOG
run: cp CHANGELOG.md site/doc/
- name: Push to pages
run: |
cd site
git config --global user.email "$GITHUB_JOB+github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions"
git add -A
git commit -m "[automated site update]" && git push || true
changelog-update:
name: Update CHANGELOG on github pages
if: github.repository_owner == 'Sigmyne' && contains(github.event.head_commit.message, 'changelog update')
runs-on: ubuntu-latest
steps:
- name: Checkout source
uses: actions/checkout@v6
- name: Checkout gh-pages
uses: actions/checkout@v6
with:
ref: 'gh-pages'
path: site
- name: Assert site/doc/
run: mkdir -p site/doc
- name: Copy CHANGELOG
run: cp CHANGELOG.md site/doc/
- name: Push to pages
run: |
cd site
git config --global user.email "$GITHUB_JOB+github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions"
git add -A
git commit -m "[automated site update]" && git push || true