Cleanup declarations in source code. #32
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: Build firmware | |
| on: | |
| push: | |
| paths: | |
| - 'fw/**' | |
| - '.github/workflows/*.yml' | |
| - '!fw/build/**' | |
| - '!fw/**/src/githash.h' | |
| - '!fw/**/nextversion' | |
| pull_request: | |
| paths: | |
| - 'fw/**' | |
| - '.github/workflows/*.yml' | |
| - '!fw/**/src/githash.h' | |
| - '!fw/**/nextversion' | |
| workflow_dispatch: | |
| workflow_call: | |
| inputs: | |
| build_type: | |
| required: false | |
| type: string | |
| jobs: | |
| load-matrix: | |
| runs-on: ubuntu-latest | |
| outputs: | |
| matrix: ${{ steps.set-matrix.outputs.matrix }} | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| - name: Load matrix from file | |
| id: set-matrix | |
| run: | | |
| MATRIX=$(python3 -c "import yaml, json; print(json.dumps({'include': yaml.safe_load(open('fw/build_matrix.yaml'))}))") | |
| echo "matrix=${MATRIX}" >> $GITHUB_OUTPUT | |
| build: | |
| runs-on: ubuntu-latest | |
| needs: load-matrix | |
| strategy: | |
| matrix: ${{ fromJson(needs.load-matrix.outputs.matrix) }} | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| with: | |
| submodules: true | |
| token: ${{ secrets.pat }} | |
| - name: Update githash.h and compile | |
| run: | | |
| set -euo pipefail | |
| BUILD_TYPE="${{ inputs.build_type }}" | |
| BT="CIBuild" | |
| if [ "$BUILD_TYPE" = "B" ]; then | |
| BT="Beta" | |
| fi | |
| if [ "$BUILD_TYPE" = "R" ]; then | |
| BT="Release" | |
| fi | |
| NEXTBUILD=0 | |
| if [ "${{ matrix.versioned }}" = "true" ]; then | |
| NEXTVERSION_PATH="fw/${{ matrix.type }}/nextversion" | |
| if [ -f "$NEXTVERSION_PATH" ]; then | |
| PREVMAJOR=$(grep '^MAJOR ' "$NEXTVERSION_PATH" | awk '{print $2}') | |
| PREVMINOR=$(grep '^MINOR ' "$NEXTVERSION_PATH" | awk '{print $2}') | |
| NEXTRELEASE=$(grep '^RELEASE ' "$NEXTVERSION_PATH" | awk '{print $2}') | |
| NEXTBUILD=$(grep '^BUILD ' "$NEXTVERSION_PATH" | awk '{print $2}') | |
| else | |
| PREVMAJOR=$(grep '^#define MAJOR' "fw/${{ matrix.type }}/src/main.cpp" | head -n 1 | awk '{print $3}') | |
| PREVMINOR=$(grep '^#define MINOR' "fw/${{ matrix.type }}/src/main.cpp" | head -n 1 | awk '{print $3}') | |
| NEXTRELEASE=0 | |
| NEXTBUILD=0 | |
| fi | |
| CURMAJOR=$(grep '^#define MAJOR' "fw/${{ matrix.type }}/src/main.cpp" | head -n 1 | awk '{print $3}') | |
| CURMINOR=$(grep '^#define MINOR' "fw/${{ matrix.type }}/src/main.cpp" | head -n 1 | awk '{print $3}') | |
| if [ "$CURMAJOR" = "$PREVMAJOR" ] && [ "$CURMINOR" = "$PREVMINOR" ]; then | |
| echo "Same version" | |
| else | |
| echo "New version, set release to 0" | |
| NEXTRELEASE=0 | |
| fi | |
| echo "// This file is overwritten by github actions, do not update it manually" > githash.h | |
| echo "String githash = \"${{ github.sha }},${BT}\";" >> githash.h | |
| echo "#define GHRELEASE ${NEXTRELEASE}" >> githash.h | |
| echo "#define GHBUILD ${NEXTBUILD}" >> githash.h | |
| echo "#define GHBUILDTYPE ${BT}" >> githash.h | |
| mv githash.h "fw/${{ matrix.type }}/src/" | |
| fi | |
| python3 -m pip install --upgrade pip | |
| python3 -m pip install platformio | |
| PROJECT_DIR="fw/${{ matrix.type }}" | |
| BUILD_DIR="${GITHUB_WORKSPACE}/fw/build" | |
| PIO_BUILD_DIR="${PROJECT_DIR}/.pio/build/${{ matrix.env }}" | |
| python3 -m platformio run -d "${PROJECT_DIR}" -e "${{ matrix.env }}" | |
| rm -rf "${BUILD_DIR}" | |
| mkdir -p "${BUILD_DIR}" | |
| HEX_PATH="${PIO_BUILD_DIR}/firmware.hex" | |
| cp "${HEX_PATH}" "${BUILD_DIR}/fw_${{ matrix.type }}_${{ matrix.name }}.hex" | |
| if [ "${{ matrix.versioned }}" = "true" ]; then | |
| NEXTBUILD=$(echo "$NEXTBUILD+1" | bc) | |
| if [ "$BUILD_TYPE" = "R" ]; then | |
| NEXTRELEASE=$(echo "$NEXTRELEASE+1" | bc) | |
| fi | |
| echo "#this file is maintained by github actions" > nextversion | |
| echo "MAJOR ${CURMAJOR}" >> nextversion | |
| echo "MINOR ${CURMINOR}" >> nextversion | |
| echo "RELEASE ${NEXTRELEASE}" >> nextversion | |
| echo "BUILD ${NEXTBUILD}" >> nextversion | |
| echo "// This file is overwritten by github actions, do not update it manually" > githash.h | |
| echo "String githash = \"${{ github.sha }},User\";" >> githash.h | |
| echo "#define GHRELEASE ${NEXTRELEASE}" >> githash.h | |
| echo "#define GHBUILD 0" >> githash.h | |
| echo "#define GHBUILDTYPE User" >> githash.h | |
| mv nextversion "fw/${{ matrix.type }}/" | |
| mv githash.h "fw/${{ matrix.type }}/src/" | |
| fi | |
| touch root | |
| - name: Store data | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: fw_${{ matrix.type }}_${{ matrix.name }} | |
| path: | | |
| fw/build/fw_${{ matrix.type }}_${{ matrix.name }}.hex | |
| fw/${{ matrix.type }}/nextversion | |
| fw/${{ matrix.type }}/src/githash.h | |
| root | |
| retention-days: 1 | |
| commit: | |
| if: github.ref == format('refs/heads/{0}', github.event.repository.default_branch) | |
| runs-on: ubuntu-latest | |
| needs: [build] | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| with: | |
| token: ${{ secrets.pat }} | |
| - run: | | |
| rm -rf fw/build || true | |
| mkdir -p fw/build | |
| mkdir -p fw/artifacts | |
| - name: Download a Build Artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| path: 'fw/artifacts/' | |
| - name: Update git hash | |
| run: | | |
| for d in `ls fw/artifacts`; | |
| do | |
| cp -R fw/artifacts/$d/* ./ ||true | |
| done | |
| rm -rf fw/artifacts | |
| rm -rf root | |
| git status | |
| - name: Get last commit message | |
| id: last-commit-message | |
| run: | | |
| echo "msg=$(git log -1 --pretty=%s)" >> $GITHUB_OUTPUT | |
| - uses: stefanzweifel/git-auto-commit-action@v4 | |
| with: | |
| commit_message: ${{ steps.last-commit-message.outputs.msg }}, extended build | |
| add_options: '-A' | |
| #commit_options: '--amend --no-edit' | |
| #push_options: '--force' | |
| skip_fetch: true |