From 5880ab8a42ea3737d81d97cbd95b175e121d3170 Mon Sep 17 00:00:00 2001 From: sudden6 Date: Wed, 11 Jul 2018 23:52:59 +0200 Subject: [PATCH] chore(deploy): add snorenotify to AppImage deployment --- appimage/build.sh | 38 +++++++++++++++++++++++++++++++------- simple_make.sh | 11 ++--------- 2 files changed, 33 insertions(+), 16 deletions(-) diff --git a/appimage/build.sh b/appimage/build.sh index e8fce9df1..4c68d5731 100755 --- a/appimage/build.sh +++ b/appimage/build.sh @@ -41,13 +41,22 @@ readonly SQLCIPHER_BUILD_DIR="$BUILD_DIR"/sqlcipher # ldqt binary readonly LDQT_BIN="/usr/lib/x86_64-linux-gnu/qt5/bin/linuxdeployqt" readonly APT_FLAGS="-y --no-install-recommends" +# snorenotify source +readonly SNORE_GIT="https://github.com/KDE/snorenotify" +# snorenotify build directory +readonly SNORE_BUILD_DIR="$BUILD_DIR"/snorenotify + # use multiple cores when building export MAKEFLAGS="-j$(nproc)" # Get packages apt-get update apt-get install $APT_FLAGS sudo ca-certificates wget build-essential fuse xxd \ -git g++ patchelf tclsh libssl-dev +git patchelf tclsh libssl-dev cmake extra-cmake-modules build-essential \ +check checkinstall libavdevice-dev libexif-dev libgdk-pixbuf2.0-dev \ +libgtk2.0-dev libopenal-dev libopus-dev libqrencode-dev libqt5opengl5-dev \ +libqt5svg5-dev libsodium-dev libtool libvpx-dev libxss-dev \ +qt5-default qttools5-dev qttools5-dev-tools qtdeclarative5-dev # get version cd "$QTOX_SRC_DIR" @@ -57,6 +66,17 @@ export VERSION=$(git rev-parse --short HEAD) # create build directory mkdir -p "$BUILD_DIR" + +# install snorenotify because it's not packaged +cd "$BUILD_DIR" +git clone "$SNORE_GIT" "$SNORE_BUILD_DIR" +cd "$SNORE_BUILD_DIR" +git checkout tags/v0.7.0 +# HACK: Kids, don't do this at your home system +cmake -DCMAKE_INSTALL_PREFIX=/usr/lib/. +make +make install + cd "$BUILD_DIR" # we need a custom built sqlcipher version because of a Debian bug @@ -74,17 +94,20 @@ make install cp -r "$QTOX_SRC_DIR" "$QTOX_BUILD_DIR" cd "$QTOX_BUILD_DIR" +./bootstrap.sh + # ensure this directory is empty rm -rf ./_build - -# reuse for our purposes, pass flags to automatically install packages -# APT_FLAGS for automatic install -# True to not install sqlcipher -./simple_make.sh "$APT_FLAGS" True +mkdir -p ./_build # build dir of simple_make cd _build +# need to build with -DDESKTOP_NOTIFICATIONS=True for snorenotify +cmake -DDESKTOP_NOTIFICATIONS=True ../ + +make + make DESTDIR="$QTOX_APP_DIR" install ; find "$QTOX_APP_DIR" # is master as of 2018-04-25 @@ -128,7 +151,8 @@ unset QTDIR; unset QT_PLUGIN_PATH; unset LD_LIBRARY_PATH; readonly QTOX_DESKTOP_FILE="$QTOX_APP_DIR"/usr/local/share/applications/*.desktop -eval "$LDQT_BIN $QTOX_DESKTOP_FILE -bundle-non-qt-libs" +eval "$LDQT_BIN $QTOX_DESKTOP_FILE -bundle-non-qt-libs -extra-plugins=libsnore-qt5" + eval "$LDQT_BIN $QTOX_DESKTOP_FILE -appimage" # Chmod since everything is root:root diff --git a/simple_make.sh b/simple_make.sh index c845123cd..7b405272a 100755 --- a/simple_make.sh +++ b/simple_make.sh @@ -1,9 +1,5 @@ #!/usr/bin/env bash -# additional flags for apt-get, used for CI -readonly APT_FLAGS=$1 -readonly WITHOUT_SQLCIPHER=$2 - set -eu -o pipefail apt_install() { @@ -32,13 +28,10 @@ apt_install() { qt5-default qttools5-dev qttools5-dev-tools + libsqlcipher-dev ) - if [ "$WITHOUT_SQLCIPHER" != "True" ]; then - apt_packages+=("libsqlcipher-dev") - fi - - sudo apt-get install $APT_FLAGS "${apt_packages[@]}" + sudo apt-get install "${apt_packages[@]}" } pacman_install() {