diff options
author | Egor Tensin <Egor.Tensin@gmail.com> | 2021-01-24 04:42:20 +0300 |
---|---|---|
committer | Egor Tensin <Egor.Tensin@gmail.com> | 2021-01-24 04:50:51 +0300 |
commit | 36b83bd0d6300d2b471aaf6d01c312c15f07eade (patch) | |
tree | 09265f87d580516725eff28aa593413464c8d629 | |
parent | bye-bye, Travis & AppVeyor! (diff) | |
download | winapi-common-36b83bd0d6300d2b471aaf6d01c312c15f07eade.tar.gz winapi-common-36b83bd0d6300d2b471aaf6d01c312c15f07eade.zip |
add GitHub workflow
-rw-r--r-- | .github/workflows/ci.yml | 83 | ||||
m--------- | cmake | 0 |
2 files changed, 83 insertions, 0 deletions
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..647ef48 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,83 @@ +name: CI + +on: + push: + pull_request: + schedule: + # Weekly, at 5:30 AM on Sunday (somewhat randomly chosen). + - cron: '30 5 * * 0' + workflow_dispatch: + +jobs: + lint: + runs-on: ubuntu-18.04 + name: Linting + if: github.ref == 'refs/heads/master' + steps: + - name: Checkout + uses: actions/checkout@v2 + with: + submodules: recursive + - name: Run clang-format + run: ./cmake/tools/clang-format.py --clang-format clang-format-9 + + build: + strategy: + matrix: + # MinGW builds are done on Linux, since it's more up-to-date there, and + # it's much faster. + os: [ubuntu-20.04, windows-2016, windows-2019] + platform: [x64, x86] + configuration: [Debug, RelWithDebInfo] + include: + # Prettier run names. + - {os: windows-2016, toolset: msvc, name: VS 2017} + - {os: windows-2019, toolset: msvc, name: VS 2019} + - {os: ubuntu-20.04, toolset: mingw, name: MinGW} + runs-on: '${{ matrix.os }}' + name: 'Build: ${{ matrix.name }} / ${{ matrix.platform }} / ${{ matrix.configuration }}' + env: + platform: '${{ matrix.platform }}' + configuration: '${{ matrix.configuration }}' + boost_version: 1.65.0 + defaults: + run: + shell: pwsh + steps: + - name: Checkout + uses: actions/checkout@v2 + with: + submodules: recursive + - name: Set up Python + uses: actions/setup-python@v2 + with: + python-version: '3.x' + - name: Set up MinGW + uses: egor-tensin/setup-mingw@v2 + with: + platform: '${{ matrix.platform }}' + if: matrix.toolset == 'mingw' + - name: Boost (MinGW) + run: | + cd cmake + python -m project.ci.github.boost --toolset '${{ matrix.toolset }}' -- --with-test + echo 'BOOST_DIR=${{ runner.workspace }}\boost' >> $env:GITHUB_ENV + if: matrix.toolset == 'mingw' + - name: Boost (MSVC) + run: | + echo "BOOST_DIR=${env:BOOST_ROOT_1_72_0}" >> $env:GITHUB_ENV + if: matrix.toolset == 'msvc' + - name: Build + run: | + cd cmake + $flags = if ('${{ matrix.toolset }}' -eq 'msvc') { + '--','-D','WINAPI_COMMON_TESTS=ON' + } else { + @() + } + python -m project.ci.github.cmake --toolset '${{ matrix.toolset }}' --boost $env:BOOST_DIR --install $flags + - name: Upload the binaries + uses: actions/upload-artifact@v2 + with: + name: 'winapi-common-${{ matrix.os }}-${{ matrix.platform }}-${{ matrix.configuration }}' + path: '${{ runner.workspace }}/install/' diff --git a/cmake b/cmake -Subproject 6413da0a45b8ee66b9a9ac0adabcbf5139ea2ff +Subproject f94b917b66deb8b6abd173547a3f36e7271f654 |