summaryrefslogtreecommitdiff
path: root/.github/workflows/doxygen.yml
blob: 35834de0a68da79fb3bd9510f7651e09a2080aae (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
name: Generate Documentation

on:
  push:
    branches: [ main ]
  pull_request:
    branches: [ main ]
  workflow_dispatch:

# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
  contents: read
  pages: write
  id-token: write

jobs:
  build-docs:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout repository
        uses: actions/checkout@v4
        with:
          submodules: recursive

      - name: Set up Python
        uses: actions/setup-python@v5
        with:
          python-version: '3.10'

      - name: Install dependencies
        run: |
          pip install jinja2 Pygments
          sudo apt-get update
          sudo apt-get install -y doxygen

      - name: Clone m.css
        run: |
          git clone https://github.com/mosra/m.css.git
          
      - name: Prepare Doxyfile
        run: |
          doxygen -g Doxyfile
          
          # Configure Doxyfile for m.css and project specifics
          sed -i 's/PROJECT_NAME.*=.*/PROJECT_NAME           = "fbgl"/g' Doxyfile
          sed -i 's/INPUT.*=.*/INPUT                  = README.md fbhl.h/g' Doxyfile
          sed -i 's/USE_MDFILE_AS_MAINPAGE.*=.*/USE_MDFILE_AS_MAINPAGE = README.md/g' Doxyfile
          sed -i 's/EXTRACT_ALL.*=.*/EXTRACT_ALL            = YES/g' Doxyfile
          sed -i 's/RECURSIVE.*=.*/RECURSIVE            = YES/g' Doxyfile
          sed -i 's/GENERATE_HTML.*=.*/GENERATE_HTML        = NO/g' Doxyfile
          
      - name: Generate Documentation with m.css
        run: |
          python3 m.css/documentation/doxygen.py Doxyfile
          
      - name: Setup Pages
        uses: actions/configure-pages@v4
        
      - name: Upload artifact
        uses: actions/upload-pages-artifact@v3
        with:
          path: 'documentation'
          
  deploy:
    environment:
      name: github-pages
      url: ${{ steps.deployment.outputs.page_url }}
    runs-on: ubuntu-latest
    needs: build-docs
    steps:
      - name: Deploy to GitHub Pages
        id: deployment
        uses: actions/deploy-pages@v4