diff options
author | b-r-o-c-k <brockmammen@gmail.com> | 2018-03-11 17:44:07 -0500 |
---|---|---|
committer | Justin M. Keyes <justinkz@gmail.com> | 2018-03-11 23:44:07 +0100 |
commit | e24e98534bbb915d484eca0056ff8b57a2eb2a1d (patch) | |
tree | 6ba6e7faea237bf9519597ab6e6bffe348ebe71a | |
parent | c7f95fde1bb1d1a245ad015be10aa4d23fc48899 (diff) | |
download | rneovim-e24e98534bbb915d484eca0056ff8b57a2eb2a1d.tar.gz rneovim-e24e98534bbb915d484eca0056ff8b57a2eb2a1d.tar.bz2 rneovim-e24e98534bbb915d484eca0056ff8b57a2eb2a1d.zip |
ci/AppVeyor: use PowerShell (#8124)
-rw-r--r-- | appveyor.yml | 4 | ||||
-rw-r--r-- | ci/build.bat | 88 | ||||
-rw-r--r-- | ci/build.ps1 | 112 |
3 files changed, 114 insertions, 90 deletions
diff --git a/appveyor.yml b/appveyor.yml index ab2bfc92fe..957efc0e47 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -16,9 +16,9 @@ install: [] before_build: - ps: Install-Product node 8 build_script: -- call ci\build.bat +- powershell ci\build.ps1 cache: -- C:\msys64\var\cache\pacman\pkg -> ci\build.bat +- C:\msys64\var\cache\pacman\pkg -> ci\build.ps1 - .deps -> third-party\** artifacts: - path: build/Neovim.zip diff --git a/ci/build.bat b/ci/build.bat deleted file mode 100644 index 8bf310851e..0000000000 --- a/ci/build.bat +++ /dev/null @@ -1,88 +0,0 @@ -echo on -if "%CONFIGURATION%" == "MINGW_32" ( - set ARCH=i686 - set BITS=32 -) else if "%CONFIGURATION:~0,8%" == "MINGW_64" ( - set ARCH=x86_64 - set BITS=64 - if "%CONFIGURATION%" == "MINGW_64-gcov" ( - set "USE_GCOV=-DUSE_GCOV=ON" - ) -) else if "%CONFIGURATION%" == "MSVC_32" ( - set "CMAKE_GENERATOR=Visual Studio 15 2017" -) else if "%CONFIGURATION%" == "MSVC_64" ( - set "CMAKE_GENERATOR=Visual Studio 15 2017 Win64" -) - -if "%CONFIGURATION:~0,5%" == "MINGW" ( - :: These are native MinGW builds, but they use the toolchain inside - :: MSYS2, this allows using all the dependencies and tools available - :: in MSYS2, but we cannot build inside the MSYS2 shell. - set "CMAKE_GENERATOR=MinGW Makefiles" - set CMAKE_GENERATOR_ARGS=VERBOSE=1 - :: Add MinGW to the PATH and remove the Git directory because it - :: has a conflicting sh.exe - set "PATH=C:\msys64\mingw%BITS%\bin;C:\Windows\System32;C:\Windows;%PATH:C:\Program Files\Git\usr\bin;=%" - :: Build third-party dependencies - C:\msys64\usr\bin\bash -lc "pacman --verbose --noconfirm -Su" || goto :error - C:\msys64\usr\bin\bash -lc "pacman --verbose --noconfirm --needed -S mingw-w64-%ARCH%-cmake mingw-w64-%ARCH%-perl mingw-w64-%ARCH%-diffutils mingw-w64-%ARCH%-unibilium gperf" || goto :error -) else if "%CONFIGURATION:~0,4%" == "MSVC" ( - set CMAKE_GENERATOR_ARGS=/verbosity:normal -) - -:: Setup python (use AppVeyor system python) -C:\Python27\python.exe -m pip install neovim || goto :error -C:\Python35\python.exe -m pip install neovim || goto :error -:: Disambiguate python3 -move c:\Python35\python.exe c:\Python35\python3.exe -set PATH=C:\Python35;C:\Python27;%PATH% -:: Sanity check -python -c "import neovim; print(str(neovim))" || goto :error -python3 -c "import neovim; print(str(neovim))" || goto :error - -set PATH=C:\Ruby24\bin;%PATH% -cmd /c gem.cmd install neovim || goto :error -where.exe neovim-ruby-host.bat || goto :error - -cmd /c npm.cmd install -g neovim || goto :error -where.exe neovim-node-host.cmd || goto :error - -mkdir .deps -cd .deps -cmake -G "%CMAKE_GENERATOR%" -DCMAKE_BUILD_TYPE=RelWithDebInfo ..\third-party\ || goto :error -cmake --build . -- %CMAKE_GENERATOR_ARGS% || goto :error -cd .. - -:: Build Neovim -mkdir build -cd build -cmake -G "%CMAKE_GENERATOR%" -DCMAKE_BUILD_TYPE=RelWithDebInfo -DBUSTED_OUTPUT_TYPE=nvim %USE_GCOV% -DGPERF_PRG="C:\msys64\usr\bin\gperf.exe" .. || goto :error -cmake --build . --config RelWithDebInfo -- %CMAKE_GENERATOR_ARGS% || goto :error -bin\nvim --version || goto :error - -:: Functional tests -cmake --build . --config RelWithDebInfo --target functionaltest -- %CMAKE_GENERATOR_ARGS% || goto :error - -if defined USE_GCOV ( - C:\msys64\usr\bin\bash -lc "cd /c/projects/neovim; bash <(curl -s https://codecov.io/bash) -c -F functionaltest || echo 'codecov upload failed.'" -) - -:: Old tests -setlocal -set PATH=%PATH%;C:\msys64\usr\bin -cmake --build "%~dp0\..\src\nvim\testdir" -- %CMAKE_GENERATOR_ARGS% -endlocal - -if defined USE_GCOV ( - C:\msys64\usr\bin\bash -lc "cd /c/projects/neovim; bash <(curl -s https://codecov.io/bash) -c -F oldtest || echo 'codecov upload failed.'" -) - -:: The default cpack in the PATH is not CMake -set "PATH=C:\Program Files (x86)\CMake\bin\cpack.exe;%PATH%" -:: Build artifacts -cpack -G ZIP -C RelWithDebInfo -if defined APPVEYOR_REPO_TAG_NAME cpack -G NSIS -C RelWithDebInfo - -goto :EOF -:error -exit /b %errorlevel% diff --git a/ci/build.ps1 b/ci/build.ps1 new file mode 100644 index 0000000000..7075775bcd --- /dev/null +++ b/ci/build.ps1 @@ -0,0 +1,112 @@ +Set-PSDebug -Trace 1 + +$env:CONFIGURATION -match '^(?<compiler>\w+)_(?<bits>32|64)(?:-(?<option>\w+))?$' +$compiler = $Matches.compiler +$compileOption = $Matches.option +$bits = $Matches.bits +$cmakeBuildType = 'RelWithDebInfo' +$depsCmakeVars = @{ + CMAKE_BUILD_TYPE = $cmakeBuildType; +} +$nvimCmakeVars = @{ + CMAKE_BUILD_TYPE = $cmakeBuildType; + BUSTED_OUTPUT_TYPE = 'nvim'; + GPERF_PRG = 'C:\msys64\usr\bin\gperf.exe'; +} + +function exitIfFailed() { + if ($LastExitCode -ne 0) { + exit $LastExitCode + } +} + +if ($compiler -eq 'MINGW') { + if ($bits -eq 32) { + $arch = 'i686' + } + elseif ($bits -eq 64) { + $arch = 'x86_64' + } + if ($compileOption -eq 'gcov') { + $nvimCmakeVars['USE_GCOV'] = 'ON' + $uploadToCodecov = $true + } + # These are native MinGW builds, but they use the toolchain inside + # MSYS2, this allows using all the dependencies and tools available + # in MSYS2, but we cannot build inside the MSYS2 shell. + $cmakeGenerator = 'MinGW Makefiles' + $cmakeGeneratorArgs = 'VERBOSE=1' + + # Add MinGW to the PATH + $env:PATH = "C:\msys64\mingw$bits\bin;$env:PATH" + # Remove the Git sh.exe from the PATH + $env:PATH = $env:PATH.Replace('C:\Program Files\Git\usr\bin', '') + + # Build third-party dependencies + C:\msys64\usr\bin\bash -lc "pacman --verbose --noconfirm -Su" ; exitIfFailed + C:\msys64\usr\bin\bash -lc "pacman --verbose --noconfirm --needed -S mingw-w64-$arch-cmake mingw-w64-$arch-perl mingw-w64-$arch-diffutils mingw-w64-$arch-unibilium gperf" ; exitIfFailed +} +elseif ($compiler -eq 'MSVC') { + $cmakeGeneratorArgs = '/verbosity:normal' + if ($bits -eq 32) { + $cmakeGenerator = 'Visual Studio 15 2017' + } + elseif ($bits -eq 64) { + $cmakeGenerator = 'Visual Studio 15 2017 Win64' + } +} + +# Setup python (use AppVeyor system python) +C:\Python27\python.exe -m pip install neovim ; exitIfFailed +C:\Python35\python.exe -m pip install neovim ; exitIfFailed +# Disambiguate python3 +move c:\Python35\python.exe c:\Python35\python3.exe +$env:PATH = "C:\Python35;C:\Python27;$env:PATH" +# Sanity check +python -c "import neovim; print(str(neovim))" ; exitIfFailed +python3 -c "import neovim; print(str(neovim))" ; exitIfFailed + +$env:PATH = "C:\Ruby24\bin;$env:PATH" +cmd /c gem.cmd install neovim ; exitIfFailed +where.exe neovim-ruby-host.bat ; exitIfFailed + +cmd /c npm.cmd install -g neovim ; exitIfFailed +where.exe neovim-node-host.cmd ; exitIfFailed + +function convertToCmakeArgs($vars) { + return $vars.GetEnumerator() | foreach { "-D$($_.Key)=$($_.Value)" } +} + +mkdir .deps +cd .deps +cmake -G $cmakeGenerator $(convertToCmakeArgs($depsCmakeVars)) ..\third-party\ ; exitIfFailed +cmake --build . --config $cmakeBuildType -- $cmakeGeneratorArgs ; exitIfFailed +cd .. + +# Build Neovim +mkdir build +cd build +cmake -G $cmakeGenerator $(convertToCmakeArgs($nvimCmakeVars)) .. ; exitIfFailed +cmake --build . --config $cmakeBuildType -- $cmakeGeneratorArgs ; exitIfFailed +bin\nvim --version ; exitIfFailed + +# Functional tests +cmake --build . --config $cmakeBuildType --target functionaltest -- $cmakeGeneratorArgs ; exitIfFailed + +if ($uploadToCodecov) { + C:\msys64\usr\bin\bash -lc "cd /c/projects/neovim; bash <(curl -s https://codecov.io/bash) -c -F functionaltest || echo 'codecov upload failed.'" +} + +# Old tests +$env:PATH += ';C:\msys64\usr\bin' +& "C:\msys64\mingw$bits\bin\mingw32-make.exe" -C $(Convert-Path ..\src\nvim\testdir) VERBOSE=1 + +if ($uploadToCodecov) { + C:\msys64\usr\bin\bash -lc "cd /c/projects/neovim; bash <(curl -s https://codecov.io/bash) -c -F oldtest || echo 'codecov upload failed.'" +} + +# Build artifacts +cpack -G ZIP -C RelWithDebInfo +if ($env:APPVEYOR_REPO_TAG_NAME -ne $null) { + cpack -G NSIS -C RelWithDebInfo +} |