From: Uwe Hermann Date: Tue, 28 Feb 2017 23:45:20 +0000 (+0100) Subject: sigrok-native-appimage: Rewrite to use local build products. X-Git-Url: https://sigrok.org/gitaction?a=commitdiff_plain;h=3d2ed47bca1612fd89aac66dcad083fdbfd068ad;p=sigrok-util.git sigrok-native-appimage: Rewrite to use local build products. The script now assumes that $HOME/sr contains a full build of all sigrok components, as performed by e.g. the sigrok-cross-linux script. Use "NIGHTLY" as version indicator in the filename. --- diff --git a/cross-compile/appimage/sigrok-native-appimage b/cross-compile/appimage/sigrok-native-appimage index a044cee..763323f 100755 --- a/cross-compile/appimage/sigrok-native-appimage +++ b/cross-compile/appimage/sigrok-native-appimage @@ -1,52 +1,38 @@ #!/bin/bash +## +## Copyright (C) 2016 Simon Peter +## Copyright (C) 2017 Uwe Hermann +## This file is licensed under the terms of the MIT license. +## -# (c) 2016 Simon Peter -# This file is licensed under the terms of the MIT license. -# -# Bundle PulseView and its dependencies as an AppImage for x86_64 Linux -# TODO: Change it to use build products and libraries from a more mature -# distribution such as Debian oldstable, CentOS 6 or Ubuntu Trusty or older. +# Bundle PulseView and its dependencies as an AppImage for x86_64 Linux. +# Note: This assumes the full sigrok stack has been installed into $PREFIX. -APP=PulseView -LOWERAPP=${APP,,} +PREFIX=$HOME/sr ARCH=x86_64 -mkdir -p ./$APP/$APP.AppDir/usr/bin ./$APP/$APP.AppDir/usr/lib +APP=PulseView +LOWERAPP=${APP,,} + +A="./$APP/$APP.AppDir" +mkdir -p $A/usr/bin $A/usr/lib $A/usr/share cd ./$APP wget -q https://github.com/probonopd/AppImages/raw/master/functions.sh -O ./functions.sh . ./functions.sh ######################################################################## -# Get build products from Jenkins -# FIXME: Do the actual building here instead +# Get build products from $PREFIX ######################################################################## -wget http://sigrok.org/jenkins/job/pulseview/buildtype=shared,compiler=gcc,platform=native-amd64/ws/_inst/bin/*zip*/bin.zip -unzip bin.zip - -FW=$(wget -q "http://sigrok.org/download/binary/sigrok-firmware-fx2lafw/?C=M;O=D" -O - | grep .tar.gz | head -n 1 | cut -d '"' -f 13 | cut -d ">" -f 2 | cut -d "<" -f 1) -wget -c "http://sigrok.org/download/binary/sigrok-firmware-fx2lafw/$FW" -tar xf sigrok-firmware-fx2lafw-bin-*.tar.gz -rm sigrok-firmware-fx2lafw-bin-*.tar.gz - cd $APP.AppDir/ -mv ../bin/pulseview usr/bin/ +cp $PREFIX/bin/pulseview usr/bin/ chmod a+x usr/bin/* - -cd usr/lib/ -wget http://sigrok.org/jenkins/job/libsigrok/buildtype=shared,compiler=gcc,platform=native-amd64/ws/_inst/lib/libsigrok.so.3 -wget http://sigrok.org/jenkins/job/libsigrok/buildtype=shared,compiler=gcc,platform=native-amd64/ws/_inst/lib/libsigrokcxx.so.3 -wget http://sigrok.org/jenkins/job/libserialport/buildtype=shared,compiler=gcc,platform=native-amd64/lastSuccessfulBuild/artifact/_inst/lib/libserialport.so.0 -cd ../../ - -wget "http://sigrok.org/jenkins/job/libsigrokdecode/buildtype=shared,compiler=gcc,platform=native-amd64/lastSuccessfulBuild/artifact/*zip*/archive.zip" -unzip archive.zip -mv archive/_inst/share/libsigrokdecode usr/share/libsigrokdecode -mv archive/_inst/lib/libsigrokdecode.so.3 usr/lib/ -rm -rf archive* +cp $PREFIX/lib/lib*.so* usr/lib/ +cp -r $PREFIX/share/libsigrokdecode usr/share/ +cp -r $PREFIX/share/sigrok-firmware usr/share/ # Reduce binary size strip usr/bin/* @@ -65,20 +51,11 @@ get_apprun wget http://sigrok.org/jenkins/job/pulseview/buildtype=shared,compiler=gcc,platform=native-amd64/ws/contrib/pulseview.desktop wget -q "http://sigrok.org/gitweb/?p=pulseview.git;a=blob_plain;f=icons/sigrok-logo-notext.png" -O sigrok-logo-notext.png -######################################################################## -# Patch away absolute paths; it would be nice if they were relative -######################################################################## - -sed -i -e 's|/home/jenkins_slave/fsroot/workspace/libsigrokdecode/buildtype/shared/compiler/gcc/platform/native-amd64/_inst/share/|.//////////////////////////////////////////////////////////////////////////////////////////////////////////////share/|g' usr/lib/libsigrokdecode.so.3 - ######################################################################## # Copy in the dependencies that cannot be assumed to be available # on all target systems ######################################################################## -mkdir -p usr/share/ -mv ../sigrok-firmware-* usr/share/sigrok-firmware - copy_deps ######################################################################## @@ -90,11 +67,14 @@ move_lib mv ./usr/lib/x86_64-linux-gnu/* usr/lib/ rm -r ./usr/lib/x86_64-linux-gnu/ +# Remove some incorrectly/unintentionally copied files. +rm -r ./home + ######################################################################## # Determine the version of the app; also include needed glibc version ######################################################################## -VER1=$(./AppRun --version | cut -d " " -f 2) +VER1="NIGHTLY" GLIBC_NEEDED=$(glibc_needed) VERSION=$VER1.glibc$GLIBC_NEEDED echo $VERSION