mirror of https://github.com/PCSX2/pcsx2.git
Merge pull request #1010 from turtleli/travisci_appveyor
Travis CI and Appveyor continuous integration
This commit is contained in:
commit
31e80c1321
|
@ -0,0 +1,23 @@
|
||||||
|
language: cpp
|
||||||
|
|
||||||
|
sudo: required
|
||||||
|
dist: trusty
|
||||||
|
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
# Version 5 seems to be whatever is latest - for now it's 5.2
|
||||||
|
- env: VERSION=5
|
||||||
|
compiler: gcc
|
||||||
|
os: linux
|
||||||
|
- env: VERSION=4.9
|
||||||
|
compiler: gcc
|
||||||
|
os: linux
|
||||||
|
- env: VERSION=3.7
|
||||||
|
compiler: clang
|
||||||
|
os: linux
|
||||||
|
|
||||||
|
before_install:
|
||||||
|
- ./travis.sh before_install
|
||||||
|
|
||||||
|
script:
|
||||||
|
- ./travis.sh script
|
|
@ -0,0 +1,35 @@
|
||||||
|
# Static build version - changing the version dynamically means you can't
|
||||||
|
# just click from github to see how things are progressing until the build has
|
||||||
|
# finished, which could be a bit annoying.
|
||||||
|
version: 1.{build}-{branch}
|
||||||
|
|
||||||
|
environment:
|
||||||
|
matrix:
|
||||||
|
- platform: Win32
|
||||||
|
target: ReleaseAll
|
||||||
|
visualstudio_string: vs2015
|
||||||
|
- platform: Win32
|
||||||
|
VisualStudioVersion: 12.0
|
||||||
|
target: ReleaseAll
|
||||||
|
visualstudio_string: vs2013
|
||||||
|
|
||||||
|
init:
|
||||||
|
# Use CRLF line endings on Windows so users can just use Notepad.
|
||||||
|
- git config --global core.autocrlf true
|
||||||
|
|
||||||
|
build_script:
|
||||||
|
- msbuild buildbot.xml /m /t:%target% /logger:"C:\Program Files\AppVeyor\BuildAgent\Appveyor.MSBuildLogger.dll"
|
||||||
|
|
||||||
|
after_build:
|
||||||
|
- ps: $env:gitrev = git describe --tags
|
||||||
|
- ps: $env:my_version = "$env:gitrev-$env:appveyor_repo_branch-$env:appveyor_build_number"
|
||||||
|
- type NUL > bin\portable.ini
|
||||||
|
- set folder_name=pcsx2-%my_version%-%visualstudio_string%-%platform%-%target%
|
||||||
|
- rename bin %folder_name%
|
||||||
|
- 7z a -mx9 %folder_name%.7z %folder_name%
|
||||||
|
|
||||||
|
test: off
|
||||||
|
|
||||||
|
artifacts:
|
||||||
|
- path: $(folder_name).7z
|
||||||
|
name: $(visualstudio_string)-$(target)
|
|
@ -0,0 +1,79 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -ex
|
||||||
|
|
||||||
|
linux_before_install() {
|
||||||
|
# Build worker is 64-bit only by default it seems.
|
||||||
|
sudo dpkg --add-architecture i386
|
||||||
|
|
||||||
|
# Compilers
|
||||||
|
if [ "${CXX}" = "clang++" ]; then
|
||||||
|
sudo apt-key adv --fetch-keys http://llvm.org/apt/llvm-snapshot.gpg.key
|
||||||
|
sudo add-apt-repository -y "deb http://llvm.org/apt/trusty/ llvm-toolchain-trusty-${VERSION} main"
|
||||||
|
# g++-4.8-multilib is necessary for compiler dependencies. Well, I think
|
||||||
|
# the specific dependency is probably lib32gcc-4.8-dev.
|
||||||
|
COMPILER_PACKAGE="clang-${VERSION} g++-4.8-multilib"
|
||||||
|
fi
|
||||||
|
if [ "${CXX}" = "g++" ]; then
|
||||||
|
sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
|
||||||
|
COMPILER_PACKAGE="g++-${VERSION}-multilib"
|
||||||
|
fi
|
||||||
|
|
||||||
|
sudo apt-get -qq update
|
||||||
|
|
||||||
|
# The 64-bit versions of the first 7 dependencies are part of the initial
|
||||||
|
# build image. libgtk2.0-dev:i386 and libsdl2-dev:i386 require the 32-bit
|
||||||
|
# versions of the dependencies, and the 2 versions conflict. So those
|
||||||
|
# dependencies must be explicitly installed.
|
||||||
|
sudo apt-get -qq -y install \
|
||||||
|
gir1.2-freedesktop:i386 \
|
||||||
|
gir1.2-gdkpixbuf-2.0:i386 \
|
||||||
|
gir1.2-glib-2.0:i386 \
|
||||||
|
libcairo2-dev:i386 \
|
||||||
|
libgdk-pixbuf2.0-dev:i386 \
|
||||||
|
libgirepository-1.0-1:i386 \
|
||||||
|
libglib2.0-dev:i386 \
|
||||||
|
libaio-dev:i386 \
|
||||||
|
libasound2-dev:i386 \
|
||||||
|
libgl1-mesa-dev:i386 \
|
||||||
|
libgtk2.0-dev:i386 \
|
||||||
|
liblzma-dev:i386 \
|
||||||
|
libpng12-dev:i386 \
|
||||||
|
libsdl2-dev:i386 \
|
||||||
|
libsoundtouch-dev:i386 \
|
||||||
|
libwxgtk3.0-dev:i386 \
|
||||||
|
libxext-dev:i386 \
|
||||||
|
portaudio19-dev:i386 \
|
||||||
|
zlib1g-dev:i386 \
|
||||||
|
${COMPILER_PACKAGE}
|
||||||
|
|
||||||
|
# libpng++-dev is noarch but doesn't install nicely.
|
||||||
|
apt-get download libpng++-dev
|
||||||
|
sudo dpkg --force-all -i $(ls | grep 'libpng++-dev')
|
||||||
|
}
|
||||||
|
|
||||||
|
linux_script() {
|
||||||
|
mkdir build
|
||||||
|
cd build
|
||||||
|
|
||||||
|
export CC=${CC}-${VERSION} CXX=${CXX}-${VERSION}
|
||||||
|
cmake \
|
||||||
|
-DCMAKE_TOOLCHAIN_FILE=cmake/linux-compiler-i386-multilib.cmake \
|
||||||
|
-DCMAKE_BUILD_TYPE=Release \
|
||||||
|
-DBUILD_REPLAY_LOADERS=TRUE \
|
||||||
|
-DCMAKE_BUILD_PO=FALSE \
|
||||||
|
..
|
||||||
|
|
||||||
|
# Documentation says 1.5 cores, so 2 or 3 threads should work ok.
|
||||||
|
make -j3 install
|
||||||
|
}
|
||||||
|
|
||||||
|
# Just in case I do manual testing and accidentally insert "rm -rf /"
|
||||||
|
case "${1}" in
|
||||||
|
before_install|script)
|
||||||
|
${TRAVIS_OS_NAME}_${1}
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Unknown command" && false
|
||||||
|
;;
|
||||||
|
esac
|
Loading…
Reference in New Issue