diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2020-12-11 17:14:34 -0800 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-12-17 09:17:54 -0800 |
commit | 80b5e7990a5c4d1335e575732e2bdb7796589f72 (patch) | |
tree | aac949cbd7c799751a093e7a3272bede7645e9c8 | |
parent | 320b4a77ef793497bcb43bd42c7958c43814f039 (diff) | |
download | subsurface-80b5e7990a5c4d1335e575732e2bdb7796589f72.tar.gz |
build-system/iOS: build Kirigami separately for iOS as well
Since the integrated build no longer seems to work, this creates a separate
Kirigami build using qmake (as I couldn't make Kirigami's cmake build work).
The install target tries to install into the Qt install which may not be
possible with a user account, so this instead uses the built library directly.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | Subsurface-mobile.pro | 1 | ||||
-rwxr-xr-x | packaging/ios/build.sh | 23 |
2 files changed, 22 insertions, 2 deletions
diff --git a/Subsurface-mobile.pro b/Subsurface-mobile.pro index 66763448f..f350c9422 100644 --- a/Subsurface-mobile.pro +++ b/Subsurface-mobile.pro @@ -372,6 +372,7 @@ ios { ../install-root/ios/lib/libgit2.a \ ../install-root/ios/lib/libzip.a \ ../install-root/ios/lib/libxslt.a \ + ../install-root/ios/lib/qml/org/kde/kirigami.2/libkirigamiplugin.a \ ../googlemaps/build-ios/libqtgeoservices_googlemaps.a \ -liconv \ -lsqlite3 \ diff --git a/packaging/ios/build.sh b/packaging/ios/build.sh index bd0897c05..119ca06ad 100755 --- a/packaging/ios/build.sh +++ b/packaging/ios/build.sh @@ -125,7 +125,6 @@ for ARCH in $ARCHS; do declare -x CXXFLAGS="$CFLAGS" declare -x LDFLAGS="$CFLAGS -lsqlite3 -lpthread -lc++ -L$SDK_DIR/usr/lib -fembed-bitcode" - # openssl build stuff. export DEVELOPER=$(xcode-select --print-path)\ export IPHONEOS_SDK_VERSION=$(xcrun --sdk iphoneos --show-sdk-version) @@ -261,13 +260,33 @@ if [ "$DEBUGRELEASE" != "Release" ] ; then fi popd +# build Kirigami +mkdir -p "$PARENT_DIR"/kirigami-build +pushd "$PARENT_DIR"/kirigami-build +"$IOS_QT"/"$QT_VERSION"/ios/bin/qmake "$SUBSURFACE_SOURCE"/mobile-widgets/3rdparty/kirigami/kirigami.pro CONFIG+=release +make +#make install +if [ "$DEBUGRELEASE" != "Release" ] ; then + "$IOS_QT"/"$QT_VERSION"/ios/bin/qmake "$SUBSURFACE_SOURCE"/mobile-widgets/3rdparty/kirigami/kirigami.pro CONFIG+=debug + make clean + make + #make install +fi +# since the install prefix for qmake is rather weirdly implemented, let's copy things by hand into the multiarch destination +mkdir -p "$INSTALL_ROOT"/../lib/qml/ +cp -a org "$INSTALL_ROOT"/../lib/qml/ +popd + # now combine the libraries into fat libraries ARCH_ROOT=$PARENT_DIR/install-root/ios cp -a "$ARCH_ROOT"/x86_64/* "$ARCH_ROOT" if [ "$TARGET" = "iphoneos" ] ; then pushd "$ARCH_ROOT"/lib for LIB in $(find . -type f -name \*.a); do - lipo "$ARCH_ROOT"/armv7/lib/"$LIB" "$ARCH_ROOT"/arm64/lib/"$LIB" "$ARCH_ROOT"/x86_64/lib/"$LIB" -create -output "$LIB" + # libkirigamiplugin is already a fat library + if grep -v -q "kirigami" <<< "$LIB" ; then + lipo "$ARCH_ROOT"/armv7/lib/"$LIB" "$ARCH_ROOT"/arm64/lib/"$LIB" "$ARCH_ROOT"/x86_64/lib/"$LIB" -create -output "$LIB" + fi done popd fi |