aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/.github/workflows/cygwin_static_libstdc++.yml
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2021-01-17 13:54:57 +0300
committerEgor Tensin <Egor.Tensin@gmail.com>2021-01-17 13:54:57 +0300
commitdd2c5b58c4fe77d7ce35f3abb6e1bb399560a2db (patch)
tree813808b873a5895d7f212f890c68ff14820dc591 /.github/workflows/cygwin_static_libstdc++.yml
parentTravis/AppVeyor: pause (diff)
downloadcmake-common-dd2c5b58c4fe77d7ce35f3abb6e1bb399560a2db.tar.gz
cmake-common-dd2c5b58c4fe77d7ce35f3abb6e1bb399560a2db.zip
GIANT CLUSTERFUCK OF A COMMIT
OK, this is epic. I was basically just trying to a) support Clang and b) add more test coverage. _THREE MONTHS_ and a few hundred CI runs later, this is what I came up with. I don't know how it ended up being what it is, but here we go. Some highlights of the changes: 1) CI builds has been moved to GitHub Actions, 2) the entire notion of a toolchain has been reworked; it now supports Clang on all platforms. * .github: this directory contains the GitHub Actions workflow scripts/actions. In the process, I created like 6 external GitHub actions, but it's still pretty massive. An upside is that it covers much more platform/toolchain combinations _and_ check a lot of the expected post-conditions. TODO: .ci/Makefile is obsolete now, as well as .travis.yml and .appveyor.yml. * common.cmake: added Clang support. In the process, a great deal has been learned about how CMake works; in particular, static runtime support has been reworked to be more robust. * project: the entire notion of a "toolchain" has been reworked. Instead of a measly --mingw parameter, there's now a separate --toolset parameter, which allows you to choose between GCC, Clang, MSVC, etc. Both Boost and CMake build scripts were enhanced greatly to support Clang and other toolchains in a more robust way.
Diffstat (limited to '.github/workflows/cygwin_static_libstdc++.yml')
-rw-r--r--.github/workflows/cygwin_static_libstdc++.yml81
1 files changed, 81 insertions, 0 deletions
diff --git a/.github/workflows/cygwin_static_libstdc++.yml b/.github/workflows/cygwin_static_libstdc++.yml
new file mode 100644
index 0000000..156b111
--- /dev/null
+++ b/.github/workflows/cygwin_static_libstdc++.yml
@@ -0,0 +1,81 @@
+# -static-libstdc++ is broken on Cygwin for some reason, as this workflow tries
+# to demonstrate. I don't know why exactly, but I'm not the only one with this
+# problem:
+#
+# * https://stackoverflow.com/q/46854365/514684
+# * https://sourceforge.net/p/stlplus/discussion/345536/thread/48c7fc9c17/?limit=25
+
+name: Cygwin & -static-libstdc++
+
+on:
+ push:
+ pull_request:
+ schedule:
+ # Weekly, at 5:30 AM on Saturday (somewhat randomly chosen).
+ - cron: '30 5 * * 6'
+ workflow_dispatch:
+
+jobs:
+ test:
+ runs-on: windows-2019
+
+ name: Test
+
+ defaults:
+ run:
+ shell: pwsh
+
+ steps:
+ - name: Checkout
+ uses: actions/checkout@v2
+
+ - name: Clean up PATH
+ uses: egor-tensin/cleanup-path@v1
+ if: runner.os == 'Windows'
+
+ - name: Set common variables
+ uses: ./.github/actions/common-variables
+ with:
+ toolset: '${{ matrix.toolset }}'
+ cygwin: 1
+
+ - name: Install Cygwin
+ uses: egor-tensin/setup-cygwin@v3
+
+ - name: Install GCC
+ uses: egor-tensin/setup-gcc@v1
+ with:
+ cygwin: 1
+
+ - name: Set up software environment
+ uses: ./.github/actions/software-environment
+ with:
+ toolset: gcc
+
+ - name: test.cpp
+ run: |
+ $src = @"
+ #include <stdexcept>
+
+ int main() {
+ std::runtime_error x{"x"};
+ std::runtime_error y{x};
+ return 0;
+ }
+ "@
+
+ echo $src > test.cpp
+
+ - name: Build w/ -static-libstdc++
+ run: C:\tools\cygwin\bin\g++.exe -static-libstdc++ -o test test.cpp
+ continue-on-error: true
+
+ - name: Should fail
+ run: $(Test-Path test.exe -Type Leaf) -and $(throw "test.exe shouldn't have been built")
+
+ - name: Build w/ --allow-multiple-definition
+ run: C:\tools\cygwin\bin\g++.exe '-Wl,--allow-multiple-definition' -static-libstdc++ -o test test.cpp
+ continue-on-error: true
+
+ - name: Should succeed
+ run: $(Test-Path test.exe -Type Leaf) -or $(throw "test.exe should have been built")