diff options
author | Egor Tensin <Egor.Tensin@gmail.com> | 2021-01-02 11:41:39 +0300 |
---|---|---|
committer | Egor Tensin <Egor.Tensin@gmail.com> | 2021-01-02 11:46:02 +0300 |
commit | 6322fa07b95c0d558c1dcd2a109696d74adbc35c (patch) | |
tree | 59a2699cef265540f3f9f26aa51161f882c922c1 | |
parent | Cygwin: proper executables instead of symlinks (diff) | |
download | setup-clang-6322fa07b95c0d558c1dcd2a109696d74adbc35c.tar.gz setup-clang-6322fa07b95c0d558c1dcd2a109696d74adbc35c.zip |
refactoring
Diffstat (limited to '')
-rw-r--r-- | action.yml | 37 |
1 files changed, 25 insertions, 12 deletions
@@ -32,6 +32,26 @@ runs: } } + function Install-Package { + param( + [Parameter(Mandatory=$true, ValueFromRemainingArguments=$true)] + [string[]] $Packages + ) + + if ($script:linux_host) { + sudo apt-get update -yq + sudo apt-get install -yq --no-install-recommends $Packages + } elseif ($script:cygwin_host) { + $choco = Locate-Choco + & $choco install -y --no-progress --source=cygwin $Packages + } elseif ($script:windows_host) { + $choco = Locate-Choco + & $choco install -y --no-progress $Packages + } else { + throw "Sorry, installing packages is unsupported on $script:os" + } + } + function Convert-CygwinPath { # Like cygpath -wa, but don't resolve symlinks. param( @@ -45,12 +65,9 @@ runs: } if ($linux_host) { - sudo apt update - if ($x64) { - sudo apt install -y clang g++ - } else { - sudo apt install -y clang g++-multilib - } + $pkgs = @('clang') + $pkgs += if ($x64) { 'g++' } else { 'g++-multilib' } + Install-Package $pkgs } elseif ($cygwin_host) { if (!$x64) { echo @' @@ -60,13 +77,11 @@ runs: If you _are_ using 32-bit Cygwin, please ignore this message. '@ } - $choco = Locate-Choco - # IDK why, but without libiconv-devel, even a "Hello, world!" # C++ app cannot be compiled as of December 2020. Also, libstdc++ # is required; it's simpler to install gcc-g++ for all the # dependencies. - & $choco install -y --no-progress --source=cygwin clang libiconv-devel gcc-g++ + Install-Package clang libiconv-devel gcc-g++ # clang/clang++ are Cygwin symlinks, pointing to clang-X.exe. It's # convenient to make proper executables instead so that they can be @@ -82,9 +97,7 @@ runs: New-Item -ItemType HardLink -Path "$link_winpath.exe" -Value $dest_winpath | Out-Null } } elseif ($windows_host) { - $choco = Locate-Choco - - & $choco install -y --no-progress llvm + Install-Package llvm echo (Join-Path $env:ProgramFiles LLVM bin) >> $env:GITHUB_PATH } else { throw "Sorry, installing Clang is unsupported on $os" |