aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2021-01-23 15:15:12 +0300
committerEgor Tensin <Egor.Tensin@gmail.com>2021-01-24 00:42:15 +0300
commitb83899a8aa649cd7a0a00b5b6cd16e0116606b74 (patch)
treedd125d3a341a2359488d95872aa3fb58baa7369d
parentremove .dockerignore (diff)
downloadwinapi-debug-b83899a8aa649cd7a0a00b5b6cd16e0116606b74.tar.gz
winapi-debug-b83899a8aa649cd7a0a00b5b6cd16e0116606b74.zip
add GitHub workflow
-rw-r--r--.github/workflows/ci.yml78
-rw-r--r--CMakeLists.txt1
m---------cmake0
3 files changed, 79 insertions, 0 deletions
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
new file mode 100644
index 0000000..29f8458
--- /dev/null
+++ b/.github/workflows/ci.yml
@@ -0,0 +1,78 @@
+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, Release]
+ 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-filesystem --with-program_options --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
+ python -m project.ci.github.cmake --toolset '${{ matrix.toolset }}' --boost $env:BOOST_DIR --install
+ - name: Upload the binaries
+ uses: actions/upload-artifact@v2
+ with:
+ name: 'pdb-repo-${{ matrix.os }}-${{ matrix.platform }}-${{ matrix.configuration }}'
+ path: '${{ runner.workspace }}/install/'
diff --git a/CMakeLists.txt b/CMakeLists.txt
index d72fac8..326519b 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -39,6 +39,7 @@ target_link_libraries(pdb_repo PRIVATE dbghelp)
if(MINGW)
# FILE_ID_INFO and friends require at least 0x0602:
+ message("MINGW")
target_compile_definitions(pdb_repo PUBLIC
NTDDI_VERSION=NTDDI_WIN8
_WIN32_WINNT=_WIN32_WINNT_WIN8)
diff --git a/cmake b/cmake
-Subproject 62a426a08b7d16e58f0c906ed382aceb9bcb9aa
+Subproject f94b917b66deb8b6abd173547a3f36e7271f654