diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index fdf82cac..a56eca6c 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -13,13 +13,18 @@ jobs: fail-fast: false matrix: toolchain: - - { name: 'MSVC', shell: 'sh', setup-cmake: true, setup-ninja: true, setup-msvc: true } - # TODO: Add back eventually, but exclude 3rdparty code from warnings as errors - - { name: 'msys2 mingw32', shell: 'msys2 {0}', msystem: mingw32, msys-env: mingw-w64-i686, clang-tidy: true, werror: true, no-dx5-libs: true } - - { name: 'msys2 mingw64', shell: 'msys2 {0}', msystem: mingw64, msys-env: mingw-w64-x86_64, clang-tidy: true, werror: true, no-dx5-libs: true } - # - { name: 'msys2 clang32', shell: 'msys2 {0}', msystem: clang32, msys-env: mingw-w64-clang-i686, clang-tidy: true, werror: true, no-dx5-libs: true } + - { name: 'MSVC (32-bit)', shell: 'sh', setup-cmake: true, setup-ninja: true, setup-msvc: true, vc-arch: 'amd64_x86', dx5-libs: true, d3drm-from-wine: false } + - { name: 'MSVC (64-bit)', shell: 'sh', setup-cmake: true, setup-ninja: true, setup-msvc: true, vc-arch: 'amd64', dx5-libs: false, d3drm-from-wine: true } + - { name: 'msys2 mingw32', shell: 'msys2 {0}', msystem: mingw32, msys-env: mingw-w64-i686, clang-tidy: true, werror: true, dx5-libs: false, d3drm-from-wine: true } + - { name: 'msys2 mingw64', shell: 'msys2 {0}', msystem: mingw64, msys-env: mingw-w64-x86_64, clang-tidy: true, werror: true, dx5-libs: false, d3drm-from-wine: true } + # - { name: 'msys2 clang32', shell: 'msys2 {0}', msystem: clang32, msys-env: mingw-w64-clang-i686, clang-tidy: true, werror: true, dx5-libs: true, d3drm-from-wine: true } steps: + - name: Setup vcvars + if: matrix.toolchain.setup-msvc + uses: ilammy/msvc-dev-cmd@v1 + with: + arch: ${{ matrix.toolchain.vc-arch }} # Figure out how to build for 32-bit arch # - name: Set up SDL # id: sdl @@ -46,12 +51,6 @@ jobs: if: matrix.toolchain.setup-ninja uses: ashutoshvarma/setup-ninja@master - - name: Setup vcvars - if: matrix.toolchain.setup-msvc - uses: ilammy/msvc-dev-cmd@v1 - with: - arch: amd64_x86 # Use the 64-bit x64-native cross tools to build 32-bit x86 code - - uses: actions/checkout@v4 with: submodules: true @@ -61,7 +60,8 @@ jobs: run: | cmake -S . -B build -GNinja \ -DCMAKE_BUILD_TYPE=Debug \ - -DISLE_USE_DX5_LIBS=${{ !matrix.toolchain.no-dx5-libs }} \ + -DISLE_USE_DX5=${{ matrix.toolchain.dx5-libs }} \ + -DISLE_D3DRM_FROM_WINE=${{ matrix.toolchain.d3drm-from-wine }} \ -DENABLE_CLANG_TIDY=${{ !!matrix.toolchain.clang-tidy }} \ -DISLE_WERROR=${{ !!matrix.toolchain.werror }} \ -Werror=dev