image: Visual Studio 2013 clone_folder: "c:\\pandoc" environment: global: WIXBIN: "c:\\Program Files (x86)\\WiX Toolset v3.11\\bin" STACK_BUILD_OPTS: "--no-terminal -j1 --no-system-ghc --install-ghc --test --local-bin-path=.\\windows" # Override the temp directory to avoid sed escaping issues # See https://github.com/haskell/cabal/issues/5386 TMP: "c:\\tmp" # see #4201, https://github.com/haskell-tools/haskell-tools/issues/277 matrix: # - BUILD_TYPE: "stack" # OSARCH: "windows-x86_64" # STACK_ROOT: "c:\\sr64" # STACK_YAML: "stack.yaml" # STACK_FLAGS: "--arch=x86_64" # ARCH: "x64" # CHOCO_OPTS: "" # - BUILD_TYPE: "stack" # OSARCH: "windows-i386" # STACK_ROOT: "c:\\sr32" # STACK_YAML: "stack.lts11.yaml" # STACK_FLAGS: "--arch=i386 --flag=hslua:lua_32bits" # ARCH: "x86" # CHOCO_OPTS: "--x86" # # note: we do a lts11 build because of # # https://github.com/commercialhaskell/stackage/issues/3385 # # with luck this will be fixed in ghc 8.6. - BUILD_TYPE: "cabal" OSARCH: "windows-i386" GHC_VERSION: "8.6.1.1" CABAL_STORE: "C:\\cs" CABAL_BUILD_OPTS: "--allow-newer=base --allow-newer=template-haskell --allow-newer=containers -flua_32bits -fembed_data_files" ARCH: "x86" CHOCO_OPTS: "--x86" skip_commits: files: - '*.md' - '*.txt' - '.travis.yml' - 'Makefile' - 'man/pandoc.1' - 'linux/*' - 'macos/*' matrix: fast_finish: true cache: - "%STACK_ROOT%" - "%CABAL_STORE%" # This is where stack install ghc by default, but we don't # cache it because it's too large: # - "c:\\Users\\appveyor\\AppData\\Local\\Programs\\stack" # Note: to reset build cache, do the following in JavaScript # console on appveyor: # $.ajax({ url: 'https://ci.appveyor.com/api/projects/jgm/pandoc/buildcache', type: 'DELETE'}) # We don't do a normal C build, but build in test_script via stack build: off install: - choco install wixtoolset %CHOCO_OPTS% - if "%BUILD_TYPE%" == "stack" ( choco install haskell-stack %CHOCO_OPTS% ) - if "%BUILD_TYPE%" == "cabal" ( choco install -y ghc --version %GHC_VERSION% --ignore-dependencies %CHOCO_OPTS% ) # before_test: test_script: # The ugly echo "" hack is to avoid complaints about 0 being an invalid file # descriptor - if "%BUILD_TYPE%" == "stack" ( stack --version && stack path && echo "" | stack clean && echo "" | stack install --stack-yaml %STACK_YAML% %STACK_BUILD_OPTS% %STACK_FLAGS% pandoc pandoc-citeproc ) - if "%BUILD_TYPE%" == "cabal" ( cabal --version && cabal --store-dir="%CABAL_STORE%" new-update && cabal --store-dir="%CABAL_STORE%" new-build %CABAL_BUILD_OPTS% . pandoc-citeproc && forfiles /P .\dist-newstyle /M pandoc*.exe /C "cmd /C cp @file .\windows\ " ) after_test: # .\ in the stack commandline seems to be .\windows\ (where the stack-appveyor.yaml is) - cd windows - .\pandoc.exe -s --toc ..\MANUAL.txt -o MANUAL.html - .\pandoc.exe -s ..\COPYING.md -o COPYING.rtf - copy ..\COPYRIGHT COPYRIGHT.txt - 7z a "pandoc-%OSARCH%.zip" pandoc.exe pandoc-citeproc.exe MANUAL.html COPYING.rtf - | set VERSION= for /f "tokens=1-2 delims= " %%a in ('.\pandoc.exe --version') do ( if not defined VERSION set "VERSION=%%b" ) echo %VERSION% "%WIXBIN%"\candle -arch %ARCH% -dVERSION=%VERSION% -dBINPATH=. *.wxs -out wixobj\ "%WIXBIN%"\light -sw1076 -ext WixUIExtension -ext WixUtilExtension -cultures:en-us -loc Pandoc-en-us.wxl -out "pandoc-%OSARCH%.msi" wixobj\*.wixobj artifacts: - path: 'windows\pandoc-%OSARCH%.zip' name: exe - path: 'windows\pandoc-%OSARCH%.msi' name: msi