summaryrefslogtreecommitdiffstats
path: root/scripts/windows-container/before_install.sh
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2018-10-06 10:11:15 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-10-07 14:00:45 -0700
commit450f654063cbbffe7b58e0b785ef8970a0be41ea (patch)
tree5295dbd03a6fb7faee6759b3e9ec288063b0b4de /scripts/windows-container/before_install.sh
parent6b9e77ba01472070dd1ac9b87c9dcb068c49b852 (diff)
downloadsubsurface-450f654063cbbffe7b58e0b785ef8970a0be41ea.tar.gz
Travis: add Windows build in a container
I expect this to become the default way to test Windows builds and create installers on Travis. The idea is that instead of downloading the pre-built MXE binaries we might as well use a container that has all this installed and can be used locally to test if things fail on Travis; which will allow us to have the exact same environment for testing locally as runs on Travis. At this point the container used is way too big - more effort needs to be spent on shrinking it. Right now this only deals with Subsurface and not with smtk2ssrf. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'scripts/windows-container/before_install.sh')
-rw-r--r--scripts/windows-container/before_install.sh62
1 files changed, 62 insertions, 0 deletions
diff --git a/scripts/windows-container/before_install.sh b/scripts/windows-container/before_install.sh
new file mode 100644
index 000000000..3c4732167
--- /dev/null
+++ b/scripts/windows-container/before_install.sh
@@ -0,0 +1,62 @@
+#!/bin/bash
+
+set -x
+set -e
+
+# when running this locally, set TRAVIS_BUILD_DIR to the Subsurface
+# directory inside your Windows build tree
+TRAVIS_BUILD_DIR=${TRAVIS_BUILD_DIR:-$PWD}
+
+git fetch --unshallow || true # if running locally, unshallow could fail
+git pull --tags
+git submodule init
+git describe
+
+# make sure we have libdivecomputer
+echo "Get libdivecomputer"
+cd ${TRAVIS_BUILD_DIR}
+git submodule update --recursive
+cd libdivecomputer
+autoreconf --install
+autoreconf --install
+
+# the intended layout as seen inside the container is
+# /win/subsurface # sources that we are testing
+# /win32 # binaries that are build
+# /grantlee
+# /libzip
+# /hidapi
+# /googlemaps
+#
+# the first two are mounted as volumes (this way we get access to the
+# build results outside of the container
+cd ${TRAVIS_BUILD_DIR}/..
+mkdir -p win32
+
+# start the container and keep it running
+docker run -v $PWD/win32:/win/win32 -v $PWD/subsurface:/win/subsurface --name=builder -w /win -d dirkhh/mxe-build-container:0.6 /bin/sleep 60m
+
+# for some reason this package was installed but still isn't there?
+docker exec -t builder apt-get install -y ca-certificates
+
+# now set up our other dependencies
+# these are either not available in MXE, or a version that's too old
+docker exec -t builder bash subsurface/scripts/get-dep-lib.sh single . libzip
+docker exec -t builder bash subsurface/scripts/get-dep-lib.sh single . hidapi
+docker exec -t builder bash subsurface/scripts/get-dep-lib.sh single . googlemaps
+docker exec -t builder bash subsurface/scripts/get-dep-lib.sh single . grantlee
+
+
+# the rest we'll need when we enable smtk2ssrf
+
+#echo "Get mdbtools"
+#cd ${TRAVIS_BUILD_DIR}/..
+#git clone https://github.com/brianb/mdbtools.git
+
+# get prebuilt mxe libraries for mdbtools and glib.
+# do not overwrite upstream prebuilt mxe binaries if there is any coincidence.
+#wget https://www.dropbox.com/s/842skyusb96ii1u/mxe-static-minimal-994ad473.tar.xz
+#[[ ! -f mxe-static-minimal-994ad473.tar.xz ]] && exit 1
+#cd mxe
+#tar -xJf ../mxe-static-minimal-994ad473.tar.xz --skip-old-files
+#ls -al usr/