diff options
author | sfan5 <sfan5@live.de> | 2014-12-05 15:54:19 +0100 |
---|---|---|
committer | sfan5 <sfan5@live.de> | 2014-12-06 19:56:31 +0100 |
commit | 04a1a446cf845a0db80d39fd0e42771aa07e4492 (patch) | |
tree | ba7e67cd87e10d427ed99eb7a6019309b9c75825 /util/travis | |
parent | 5062b99cb0d252d9e377ff4560f7ecc9e66fd558 (diff) | |
download | minetest-04a1a446cf845a0db80d39fd0e42771aa07e4492.tar.gz minetest-04a1a446cf845a0db80d39fd0e42771aa07e4492.tar.bz2 minetest-04a1a446cf845a0db80d39fd0e42771aa07e4492.zip |
Build for win32 & win64 on Travis too
Diffstat (limited to 'util/travis')
-rwxr-xr-x | util/travis/before_install.sh | 29 | ||||
-rwxr-xr-x | util/travis/script.sh | 24 | ||||
-rw-r--r-- | util/travis/toolchain_mingw.cmake.in | 17 |
3 files changed, 70 insertions, 0 deletions
diff --git a/util/travis/before_install.sh b/util/travis/before_install.sh new file mode 100755 index 000000000..233e8ba95 --- /dev/null +++ b/util/travis/before_install.sh @@ -0,0 +1,29 @@ +#!/bin/bash -e + +if [ $CC = "clang" ]; then + export PATH="/usr/bin/:$PATH" + sudo sh -c 'echo "deb http://ppa.launchpad.net/eudoxos/llvm-3.1/ubuntu precise main" >> /etc/apt/sources.list' + sudo apt-key adv --keyserver pool.sks-keyservers.net --recv-keys 92DE8183 + sudo apt-get update + sudo apt-get install llvm-3.1 + sudo apt-get install clang +fi +if [ $WINDOWS = "no" ]; then + sudo apt-get install libirrlicht-dev cmake libbz2-dev libpng12-dev \ + libjpeg8-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev \ + libvorbis-dev libopenal-dev gettext +else + sudo apt-get install p7zip-full + if [ $WINDOWS = "32" ]; then + wget http://meow.minetest.net/mingw_w64_i686_ubuntu12.04_4.9.1.7z -O mingw.7z + sed -e "s|%PREFIX%|i686-w64-mingw32|" \ + -e "s|%ROOTPATH%|/usr/i686-w64-mingw32|" \ + < util/travis/toolchain_mingw.cmake.in > util/buildbot/toolchain_mingw.cmake + elif [ $WINDOWS = "64" ]; then + wget http://meow.minetest.net/mingw_w64_x86_64_ubuntu12.04_4.9.1.7z -O mingw.7z + sed -e "s|%PREFIX%|x86_64-w64-mingw32|" \ + -e "s|%ROOTPATH%|/usr/x86_64-w64-mingw32|" \ + < util/travis/toolchain_mingw.cmake.in > util/buildbot/toolchain_mingw64.cmake + fi + sudo 7z x -y -o/usr mingw.7z +fi diff --git a/util/travis/script.sh b/util/travis/script.sh new file mode 100755 index 000000000..a8e2634e9 --- /dev/null +++ b/util/travis/script.sh @@ -0,0 +1,24 @@ +#!/bin/bash -e + +if [ $WINDOWS = "no" ]; then + mkdir -p travisbuild + cd travisbuild + cmake -DENABLE_GETTEXT=1 .. + make -j2 +else + [ $CC = "clang" ] && exit 1 # Not supposed to happen + # We need to have our build directory outside of the minetest directory because + # CMake will otherwise get very very confused with symlinks and complain that + # something is not a subdirectory of something even if it actually is. + # e.g.: + # /home/travis/minetest/minetest/travisbuild/minetest + # \/ \/ \/ + # /home/travis/minetest/minetest/travisbuild/minetest/travisbuild/minetest + # \/ \/ \/ + # /home/travis/minetest/minetest/travisbuild/minetest/travisbuild/minetest/travisbuild/minetest + # You get the idea. + OLDDIR=`pwd` + cd .. + [ $WINDOWS = "32" ] && EXISTING_MINETEST_DIR=$OLDDIR NO_MINETEST_GAME=1 $OLDDIR/util/buildbot/buildwin32.sh travisbuild && exit 0 + [ $WINDOWS = "64" ] && EXISTING_MINETEST_DIR=$OLDDIR NO_MINETEST_GAME=1 $OLDDIR/util/buildbot/buildwin64.sh travisbuild && exit 0 +fi diff --git a/util/travis/toolchain_mingw.cmake.in b/util/travis/toolchain_mingw.cmake.in new file mode 100644 index 000000000..44830eb60 --- /dev/null +++ b/util/travis/toolchain_mingw.cmake.in @@ -0,0 +1,17 @@ +# name of the target operating system +SET(CMAKE_SYSTEM_NAME Windows) + +# which compilers to use for C and C++ +SET(CMAKE_C_COMPILER %PREFIX%-gcc) +SET(CMAKE_CXX_COMPILER %PREFIX%-g++) +SET(CMAKE_RC_COMPILER %PREFIX%-windres) + +# here is the target environment located +SET(CMAKE_FIND_ROOT_PATH %ROOTPATH%) + +# adjust the default behaviour of the FIND_XXX() commands: +# search headers and libraries in the target environment, search +# programs in the host environment +set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) +set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) |