aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xscripts/build.sh70
1 files changed, 46 insertions, 24 deletions
diff --git a/scripts/build.sh b/scripts/build.sh
index b28cffd83..134aa1c7d 100755
--- a/scripts/build.sh
+++ b/scripts/build.sh
@@ -23,10 +23,25 @@ exec 1> >(tee build.log) 2>&1
SRC=$(pwd)
PLATFORM=$(uname)
-# to build Subsurface-mobile on the desktop change this to
-# SUBSURFACE_EXECUTABLE=MobileExecutable
-SUBSURFACE_EXECUTABLE=DesktopExecutable
-
+# normally this script builds the desktop version in subsurface/build
+# if the first argument is "-mobile" then build Subsurface-mobile in subsurface/build-mobile
+# if the first argument is "-both" then build both in subsurface/build and subsurface/build-mobile
+BUILD="Desktop"
+if [ "$1" = "-mobile" ] ; then
+ echo "building Subsurface-mobile in subsurface/build-mobile"
+ BUILDS=( "MobileExecutable" )
+ BUILDDIRS=( "build-mobile" )
+ shift
+elif [ "$1" = "-both" ] ; then
+ echo "building both Subsurface and Subsurface-mobile in subsurface/build and subsurface/build-mobile, respectively"
+ BUILDS=( "DesktopExecutable" "MobileExecutable" )
+ BUILDDIRS=( "build" "build-mobile" )
+ shift
+else
+ echo "building Subsurface in subsurface/build"
+ BUILDS=( "DesktopExecutable" )
+ BUILDDIRS=( "build" )
+fi
if [[ ! -d "subsurface" ]] ; then
echo "please start this script from the directory containing the Subsurface source directory"
@@ -183,25 +198,32 @@ else
fi
cd $SRC/subsurface
-mkdir -p build
-cd build
-export CMAKE_PREFIX_PATH=$INSTALL_ROOT/lib/cmake
-cmake -DCMAKE_BUILD_TYPE=Debug .. \
- -DSUBSURFACE_TARGET_EXECUTABLE=$SUBSURFACE_EXECUTABLE \
- -DLIBGIT2_INCLUDE_DIR=$INSTALL_ROOT/include \
- -DLIBGIT2_LIBRARIES=$INSTALL_ROOT/lib/libgit2.$SH_LIB_EXT \
- -DLIBDIVECOMPUTER_INCLUDE_DIR=$INSTALL_ROOT/include \
- -DLIBDIVECOMPUTER_LIBRARIES=$INSTALL_ROOT/lib/libdivecomputer.a \
- -DMARBLE_INCLUDE_DIR=$INSTALL_ROOT/include \
- -DMARBLE_LIBRARIES=$INSTALL_ROOT/lib/libssrfmarblewidget.$SH_LIB_EXT \
- -DNO_PRINTING=OFF
-
-if [ $PLATFORM = Darwin ] ; then
- rm -rf Subsurface.app
-fi
+for (( i=0 ; i < ${#BUILDS[@]} ; i++ )) ; do
+ SUBSURFACE_EXECUTABLE=${BUILDS[$i]}
+ BUILDDIR=${BUILDDIRS[$i]}
+ echo "build $SUBSURFACE_EXECUTABLE in $BUILDDIR"
+
+ mkdir -p $SRC/subsurface/$BUILDDIR
+ cd $SRC/subsurface/$BUILDDIR
+ export CMAKE_PREFIX_PATH=$INSTALL_ROOT/lib/cmake
+ cmake -DCMAKE_BUILD_TYPE=Debug .. \
+ -DSUBSURFACE_TARGET_EXECUTABLE=$SUBSURFACE_EXECUTABLE \
+ -DLIBGIT2_INCLUDE_DIR=$INSTALL_ROOT/include \
+ -DLIBGIT2_LIBRARIES=$INSTALL_ROOT/lib/libgit2.$SH_LIB_EXT \
+ -DLIBDIVECOMPUTER_INCLUDE_DIR=$INSTALL_ROOT/include \
+ -DLIBDIVECOMPUTER_LIBRARIES=$INSTALL_ROOT/lib/libdivecomputer.a \
+ -DMARBLE_INCLUDE_DIR=$INSTALL_ROOT/include \
+ -DMARBLE_LIBRARIES=$INSTALL_ROOT/lib/libssrfmarblewidget.$SH_LIB_EXT \
+ -DNO_PRINTING=OFF
+
+ if [ $PLATFORM = Darwin ] ; then
+ rm -rf Subsurface.app
+ rm -rf Subsurface-mobile.app
+ fi
-LIBRARY_PATH=$INSTALL_ROOT/lib make -j4
+ LIBRARY_PATH=$INSTALL_ROOT/lib make -j4
-if [ $PLATFORM = Darwin ] ; then
- LIBRARY_PATH=$INSTALL_ROOT/lib make install
-fi
+ if [ $PLATFORM = Darwin ] ; then
+ LIBRARY_PATH=$INSTALL_ROOT/lib make install
+ fi
+done