aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/.github/actions/common-variables
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/common-variables
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 '')
-rw-r--r--.github/actions/common-variables/action.yml85
1 files changed, 85 insertions, 0 deletions
diff --git a/.github/actions/common-variables/action.yml b/.github/actions/common-variables/action.yml
new file mode 100644
index 0000000..3d40cdd
--- /dev/null
+++ b/.github/actions/common-variables/action.yml
@@ -0,0 +1,85 @@
+name: Set common variables
+description: Set common run variables
+inputs:
+ toolset:
+ description: Toolset used
+ required: true
+ cygwin:
+ description: Targeting Cygwin
+ required: false
+ default: 0
+runs:
+ using: composite
+ steps:
+ - run: |
+ New-Variable toolset -Value '${{ inputs.toolset }}' -Option Constant
+ New-Variable cygwin -Value ('${{ inputs.cygwin }}' -eq '1') -Option Constant
+
+ New-Variable os -Value '${{ runner.os }}' -Option Constant
+
+ New-Variable host_linux -Value ($os -eq 'Linux') -Option Constant
+ New-Variable host_cygwin -Value $cygwin -Option Constant
+ New-Variable host_windows -Value ($os -eq 'Windows' -and !$host_cygwin) -Option Constant
+
+ New-Variable mingw -Value ($toolset -eq 'mingw' -or ($host_windows -and $toolset -eq 'gcc')) -Option Constant
+
+ New-Variable target_linux -Value ($host_linux -and !$mingw) -Option Constant
+ New-Variable target_cygwin -Value ($host_cygwin -and !$mingw) -Option Constant
+ New-Variable target_windows -Value ($mingw -or $host_windows) -Option Constant
+
+ New-Variable target_pe -Value ($target_windows -or $target_cygwin) -Option Constant
+ New-Variable target_elf -Value $target_linux -Option Constant
+
+ function Set-BoolVar {
+ param(
+ [Parameter(Mandatory=$true)]
+ [string] $name,
+ [Parameter(Mandatory=$true)]
+ [bool] $value
+ )
+
+ $str_value = if ($value) { '1' } else { '' }
+ $msg = "$name=$str_value"
+ echo $msg
+ echo $msg >> $env:GITHUB_ENV
+ }
+
+ function Set-StrVar {
+ param(
+ [Parameter(Mandatory=$true)]
+ [string] $name,
+ [string] $value
+ )
+
+ $msg = "$name=$value"
+ echo $msg
+ echo $msg >> $env:GITHUB_ENV
+ }
+
+ Set-BoolVar 'CI_HOST_LINUX' $host_linux
+ Set-BoolVar 'CI_HOST_CYGWIN' $host_cygwin
+ Set-BoolVar 'CI_HOST_WINDOWS' $host_windows
+ Set-BoolVar 'CI_MINGW' $mingw
+ Set-BoolVar 'CI_TARGET_LINUX' $target_linux
+ Set-BoolVar 'CI_TARGET_CYGWIN' $target_cygwin
+ Set-BoolVar 'CI_TARGET_WINDOWS' $target_windows
+
+ Set-BoolVar 'CI_TARGET_PE' $target_pe
+ Set-BoolVar 'CI_TARGET_ELF' $target_elf
+
+ $lib_prefix = 'lib'
+ $lib_ext = if ($target_windows -and -not $mingw) { '.lib' } else { '.a' }
+
+ $dll_prefix = if ($target_windows -and -not $mingw) { '' } elseif ($target_cygwin) { 'cyg' } else { 'lib' }
+ $dll_ext = if ($target_windows -or $target_cygwin) { '.dll' } else { '.so' }
+
+ $exe_ext = if ($target_pe) { '.exe' } else { '' }
+
+ Set-StrVar 'CI_LIB_PREFIX' $lib_prefix
+ Set-StrVar 'CI_LIB_EXT' $lib_ext
+ Set-StrVar 'CI_DLL_PREFIX' $dll_prefix
+ Set-StrVar 'CI_DLL_EXT' $dll_ext
+ Set-StrVar 'CI_EXE_EXT' $exe_ext
+
+ Set-BoolVar 'CI_DLL_IN_BIN' $target_pe
+ shell: pwsh