aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/.github/actions/check-boost-libraries
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/actions/check-boost-libraries
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/actions/check-boost-libraries')
-rw-r--r--.github/actions/check-boost-libraries/action.yml77
1 files changed, 77 insertions, 0 deletions
diff --git a/.github/actions/check-boost-libraries/action.yml b/.github/actions/check-boost-libraries/action.yml
new file mode 100644
index 0000000..88df016
--- /dev/null
+++ b/.github/actions/check-boost-libraries/action.yml
@@ -0,0 +1,77 @@
+name: Check that Boost libraries were built
+description: Check that Boost libraries were built
+inputs:
+ boost-dir:
+ description: Boost directory
+ required: false
+ libraries:
+ description: Libraries to check
+ required: true
+ platform:
+ description: Target platform
+ required: false
+ default: x64
+ configuration:
+ description: Configuration to check
+ required: false
+ default: Debug
+runs:
+ using: composite
+ steps:
+ - run: |
+ $boost_dir = '${{ inputs.boost-dir }}'
+ if (-not $boost_dir) {
+ $boost_dir = $env:BOOST_DIR
+ }
+
+ $libraries = '${{ inputs.libraries }}'
+ $libraries = $libraries.Split(' ')
+
+ $stagedir = Join-Path 'stage' '${{ inputs.platform }}' '${{ inputs.configuration }}'
+ $librarydir = Join-Path $boost_dir $stagedir 'lib'
+
+ function Get-FileStubs {
+ param(
+ [Parameter(Mandatory=$true)]
+ [string] $lib
+ )
+
+ if ($lib -eq 'test') {
+ "prg_exec_monitor","test_exec_monitor","unit_test_framework"
+ } else {
+ @($lib)
+ }
+ }
+
+ $files = @()
+ foreach ($lib in $libraries) {
+ $stubs = Get-FileStubs $lib
+ foreach ($stub in $stubs) {
+ $files += "${env:CI_LIB_PREFIX}boost_$stub${env:CI_LIB_EXT}"
+ }
+ }
+ $files = $files | Sort-Object
+
+ echo '----------------------------------------------------------------'
+ echo 'Expected files'
+ echo '----------------------------------------------------------------'
+ echo $files
+
+ echo ''
+ echo '----------------------------------------------------------------'
+ echo 'Actual files'
+ echo '----------------------------------------------------------------'
+ echo (Get-ChildItem $librarydir | Sort-Object Name).Name
+
+ $missing = @()
+
+ foreach ($file in $files) {
+ if (!(Test-Path (Join-Path $librarydir $file) -Type Leaf)) {
+ $missing += $file
+ }
+ }
+
+ if ($missing.Count -ne 0) {
+ throw "These libraries are missing: $($missing -join ', ')"
+ }
+ shell: pwsh