X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=tools%2Flinux_packaging%2Fbuild;h=0915beba3a720c9c842311b00adfb276f91c0655;hb=adc84271ba721fdf49f4c0542e1ce3a4aca6fa2e;hp=3bf793a6371ce717096b0684be13be4e20d872bb;hpb=e5888d398350b26ba2cdc634cc9791e90b4fc6b6;p=ardour.git diff --git a/tools/linux_packaging/build b/tools/linux_packaging/build index 3bf793a637..0915beba3a 100755 --- a/tools/linux_packaging/build +++ b/tools/linux_packaging/build @@ -14,12 +14,16 @@ ARDOURSTACK_ROOT=$HOME/a3/inst # the waf build tree to use when copying built/generated files BUILD_ROOT=../../build +. ../define_versions.sh + # where harvid and xjadeo binaries are cached if test -z "$CACHEDIR" -o ! -d "$CACHEDIR"; then CACHEDIR=`pwd` fi MIXBUS= +WITH_HARRISON_LV2= +WITH_X42_LV2= WITH_LADSPA=0 WITH_HARVID= STRIP=all @@ -27,6 +31,7 @@ PRINT_SYSDEPS= WITH_NLS= EXTERNAL_JACK= VENDOR=Ardour ; +EXENAME=ardour BUILDTYPE="" @@ -49,11 +54,14 @@ while [ $# -gt 0 ] ; do --mixbus) MIXBUS=1; + WITH_HARRISON_LV2=1 ; + WITH_X42_LV2=1 ; WITH_NLS=1 ; WITH_LADSPA=; STRIP=all APPNAME=Mixbus ; - VENDOR=Harrison ; + VENDOR=Harrison ; + EXENAME=mixbus ; shift ;; --public) WITH_NLS=1 ; @@ -97,8 +105,12 @@ fi . ../define_versions.sh -echo "Version is $version / $commit" -info_string="$version ($commit) built on `hostname` by `whoami` on `date`" +echo "Version is $release_version" +if [ "x$commit" != "x" ] ; then + info_string="$release_version ($commit) built on `hostname` by `whoami` on `date`" +else + info_string="$release_version built on `hostname` by `whoami` on `date`" +fi echo "Info string is $info_string" # Figure out our CPU type @@ -106,12 +118,16 @@ case `uname -m` in i[3456789]86|x86|i86pc) echo "Architecture is x86" ARCH='x86' + WARCH='i386' + HARCH='linux32' ARCH_BITS='32-bit' MULTIARCH='i386-linux-gnu' ;; x86_64|amd64|AMD64) echo "Architecture is x86_64" ARCH='x86_64' + WARCH='x86_64' + HARCH='linux64' ARCH_BITS='64-bit' MULTIARCH='x86_64-linux-gnu' ;; @@ -134,11 +150,11 @@ fi # setup directory structure if [ -z "${BUILDTYPE}" ]; then - APPDIR=${APPNAME}_${ARCH}-${version} - APP_VER_NAME=${APPNAME}-${version} + APPDIR=${APPNAME}_${ARCH}-${release_version} + APP_VER_NAME=${APPNAME}-${release_version} else - APPDIR=${APPNAME}_${ARCH}-${version}-${BUILDTYPE} - APP_VER_NAME=${APPNAME}-${version}-${BUILDTYPE} + APPDIR=${APPNAME}_${ARCH}-${release_version}-${BUILDTYPE} + APP_VER_NAME=${APPNAME}-${release_version}-${BUILDTYPE} fi APPBIN=$APPDIR/bin @@ -161,6 +177,7 @@ Locale=$Shared/locale MidiMaps=$Shared/midi_maps PatchFiles=$Shared/patchfiles MackieControl=$Shared/mcp +VFork=$Libraries/vfork if [ x$PRINT_SYSDEPS != x ] ; then # @@ -201,6 +218,7 @@ mkdir -p $Panners mkdir -p $Backends mkdir -p $Templates mkdir -p $Shared/doc +mkdir -p $VFork # maybe set variables ENVIRONMENT=environment @@ -214,7 +232,6 @@ if test x$MIXBUS != x ; then # echo export ARDOUR_KEYBOARD_LAYOUT=us-nokeypad >> $ENVIRONMENT echo export ARDOUR_UI_CONF=ardour3_ui.conf >> $ENVIRONMENT - echo export ARDOUR3_UI_RC=ardour3_ui_dark.rc >> $ENVIRONMENT fi # @@ -226,14 +243,13 @@ echo export 'PATH=/usr/local/bin:/opt/bin:$PATH' >> $ENVIRONMENT # create startup helper script -sed -e "/^%ENV%/r $ENVIRONMENT" -e '/^%ENV%/d' -e 's/%VER%/'"${release_version}"'/' < ardour.sh.in > $APPBIN/ardour3 -rm $ENVIRONMENT && chmod 775 $APPBIN/ardour3 -MAIN_EXECUTABLE=ardour-${release_version} +sed -e "/^%ENV%/r $ENVIRONMENT" -e '/^%ENV%/d' -e 's/%VER%/'"${release_version}"'/;s/%EXENAME%/'"${EXENAME}"'/' < ardour.sh.in > $APPBIN/${EXENAME}${major_version} +rm $ENVIRONMENT && chmod 775 $APPBIN/${EXENAME}${major_version} echo "Copying ardour executable ...." -cp $BUILD_ROOT/gtk2_ardour/$MAIN_EXECUTABLE $APPBIN +cp -v $BUILD_ROOT/gtk2_ardour/ardour-${release_version} $APPBIN/${EXENAME}-${release_version} if test x$STRIP = xall ; then - strip $APPBIN/$MAIN_EXECUTABLE + strip $APPBIN/${EXENAME}-${release_version} fi # copy locale files @@ -303,22 +319,6 @@ fi # cp -R $GTKSTACK_ROOT/etc/* $Etc -echo "Copying all Pango modules ..." -cp -R $GTKSTACK_ROOT/lib/pango/1.8.0/modules/*.so $Modules -echo "Copying all GDK Pixbuf loaders ..." -cp -R $GTKSTACK_ROOT/lib/gdk-pixbuf-2.0/2.10.0/loaders/*.so $Loaders - -# Generate a pango module file using the actual Pango that we're going to bundle - -cat > pangorc < $Etc/pango.modules.in -rm pangorc - -# Ditto for gdk-pixbuf loaders -gdk-pixbuf-query-loaders | sed "s?$GTKSTACK_ROOT/lib/gdk-pixbuf-2.0/2.10.0/?@ROOTDIR@/?" > $Etc/gdk-pixbuf.loaders.in # We rely on clearlooks, so include a version from our own build tree # this one is special - we will set GTK_PATH to $Libraries/gtkengines @@ -385,16 +385,43 @@ done cp $BUILD_ROOT/libs/panners/*/lib*.so* $Panners # Backends -cp $BUILD_ROOT/libs/backends/*/lib*.so* $Backends +for backend in jack alsa dummy wavesaudio ; do + cp $BUILD_ROOT/libs/backends/$backend/lib*.so* $Backends +done # VAMP plugins that we use cp $BUILD_ROOT/libs/vamp-plugins/libardourvampplugins.so* $Libraries -# Suil modules -cp $ARDOURSTACK_ROOT/lib/suil-0/lib* $Libraries +# Suil modules (new dir 'build-stack') +if test -d $GTKSTACK_ROOT/lib/suil-0/ ; then + cp $GTKSTACK_ROOT/lib/suil-0/lib* $Libraries +fi + +# Suil modules (old dir 'build-ardour-stack') +if test -d $ARDOURSTACK_ROOT/lib/suil-0/ ; then + cp $ARDOURSTACK_ROOT/lib/suil-0/lib* $Libraries +fi + +# VST scanner app (both LXVST as well as WIN-VST, 2in1) +# (if build with wine: ardour-vst-scanner is a wrapper +# script for ardour-vst-scanner.exe.so, if VST is disabled +# neither binary nor script exists) +if test -d $BUILD_ROOT/libs/fst ; then + cp $BUILD_ROOT/libs/fst/ardour-vst-scanner* $APPLIB || true +fi + +# vfork wrapper +if test -f $BUILD_ROOT/libs/vfork/ardour-exec-wrapper ; then + cp $BUILD_ROOT/libs/vfork/ardour-exec-wrapper $APPLIB +fi + +# ALSA device reservation tool (if available) +if test -f $BUILD_ROOT/libs/ardouralsautil/ardour-request-device; then + cp $BUILD_ROOT/libs/ardouralsautil/ardour-request-device $APPLIB/ || true +fi OURLIBDIR=$BUILD_ROOT/libs -OURLIBS=$OURLIBDIR/vamp-sdk:$OURLIBDIR/surfaces/control_protocol:$OURLIBDIR/ardour:$OURLIBDIR/midi++2:$OURLIBDIR/pbd:$OURLIBDIR/rubberband:$OURLIBDIR/soundtouch:$OURLIBDIR/gtkmm2ext:$OURLIBDIR/sigc++2:$OURLIBDIR/glibmm2:$OURLIBDIR/gtkmm2/atk:$OURLIBDIR/gtkmm2/pango:$OURLIBDIR/gtkmm2/gdk:$OURLIBDIR/gtkmm2/gtk:$OURLIBDIR/libgnomecanvasmm:$OURLIBDIR/libsndfile:$OURLIBDIR/evoral:$OURLIBDIR/evoral/src/libsmf:$OURLIBDIR/audiographer:$OURLIBDIR/timecode:$OURLIBDIR/taglib:$OURLIBDIR/libltc:$OURLIBDIR/qm-dsp +OURLIBS=$OURLIBDIR/vamp-sdk:$OURLIBDIR/surfaces/control_protocol:$OURLIBDIR/ardour:$OURLIBDIR/midi++2:$OURLIBDIR/pbd:$OURLIBDIR/rubberband:$OURLIBDIR/soundtouch:$OURLIBDIR/gtkmm2ext:$OURLIBDIR/sigc++2:$OURLIBDIR/glibmm2:$OURLIBDIR/gtkmm2/atk:$OURLIBDIR/gtkmm2/pango:$OURLIBDIR/gtkmm2/gdk:$OURLIBDIR/gtkmm2/gtk:$OURLIBDIR/canvas:$OURLIBDIR/libsndfile:$OURLIBDIR/evoral:$OURLIBDIR/evoral/src/libsmf:$OURLIBDIR/audiographer:$OURLIBDIR/timecode:$OURLIBDIR/taglib:$OURLIBDIR/libltc:$OURLIBDIR/qm-dsp:$OURLIBDIR/ardouralsautil:$OURLIBDIR/ptformat echo $OURLIBS${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH} @@ -404,7 +431,7 @@ deplibs= while [ true ] ; do missing=false filelist=`find $APPLIB/ -type f` - filelist="$APPBIN/$MAIN_EXECUTABLE $filelist" + filelist="$APPBIN/${EXENAME}-${release_version} $filelist" for file in $filelist ; do if ! file $file | grep -qs ELF ; then @@ -419,6 +446,9 @@ while [ true ] ; do done depCheckedList[$checkIdx]=$file checkIdx=$(($checkIdx + 1)) + + # ignore suil/qt wrappers - the plugin will pull in QT4. + if echo $file | grep -qs 'libsuil_.*qt4' ; then continue; fi # do not include libjack deps=`LD_LIBRARY_PATH=$OURLIBS${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH} ldd $file | awk '{print $3}'` @@ -453,6 +483,8 @@ while [ true ] ; do if echo $dep | grep -qs 'libc\.' ; then continue; fi # don't include libstdc++ if echo $dep | grep -qs libstdc++ ; then continue; fi + # don't include libdbus + if echo $dep | grep -qs libdbus ; then continue; fi base=`basename $dep` if ! test -f $Libraries/$base; then @@ -488,37 +520,38 @@ echo if test x$STRIP = xall ; then echo Stripping all libraries # Must be writable so that we can strip - find $APPLIB/ -name "*.so*" | xargs chmod u+w + find $APPLIB/ -name "*.so*" -print0 | xargs -0 chmod u+w # and strip ... - find $APPLIB/ -name "*.so*" | xargs strip + find $APPLIB/ -name "*.so*" -print0 | xargs -0 strip -s elif test x$STRIP = xsome ; then echo Stripping dependent libraries for l in $deplibs ; do chmod u+w $APPLIB/$l - strip $APPLIB/$l + strip -s $APPLIB/$l done fi -find $APPLIB/ -name "*.so*" | xargs chmod a+rx +find $APPLIB/ -name "*.so*" -print0 | xargs -0 chmod a+rx echo "Copying other stuff to $APPDIR ..." # these are all generated by waf -#cp $BUILD_ROOT/gtk2_ardour/ergonomic-us.bindings $Etc cp $BUILD_ROOT/gtk2_ardour/mnemonic-us.bindings $Etc cp $BUILD_ROOT/gtk2_ardour/ardour.menus $Etc -cp ../../ardour_system.rc $Etc/ardour_system.rc -cp $BUILD_ROOT/gtk2_ardour/ardour3_ui_*.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/clearlooks.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/default_ui_config $Etc -# these are copied straight from the source tree +# Copied directly from source tree -cp ../../gtk2_ardour/ardour3_ui_default.conf $Etc/ardour3_ui_default.conf -cp ../../gtk2_ardour/ardour3_ui_default.conf $Etc/ardour3_ui.conf -cp ../../instant.xml $Etc/instant.xml +cp ../../system_config $Etc/system_config +cp ../../gtk2_ardour/dark.colors $Etc +cp ../../instant.xml $Shared/instant.xml cp ../../gtk2_ardour/step_editing.bindings $Etc cp ../../gtk2_ardour/mixer.bindings $Etc cp -r ../../gtk2_ardour/icons $Shared cp -r ../../gtk2_ardour/pixmaps $Shared - +cp -r ../../gtk2_ardour/splash.png $Shared +cp -r ../../gtk2_ardour/small-splash.png $Shared +cp -r ../../gtk2_ardour/ArdourMono.ttf $Shared # # put sooper sekrit ingredients here and they will be copied @@ -528,17 +561,72 @@ if [ -d specialSauce ] ; then cp -r specialSauce $Etc fi -# share stuff +# install bundled LV2s to /lib/LV2/ +cp -R $BUILD_ROOT/libs/LV2 $APPLIB/ -cp -R ../../gtk2_ardour/splash.png $Shared -cp -R ../../gtk2_ardour/small-splash.png $Shared -cp -R ../../gtk2_ardour/ArdourMono.ttf $Shared +# lv2 core, classifications etc - TODO check if we need the complete LV2 ontology +if test -d $ARDOURSTACK_ROOT/lib/lv2/lv2core.lv2 ; then + cp -R $ARDOURSTACK_ROOT/lib/lv2/lv2core.lv2 $APPLIB/LV2/ +elif test -d $GTKSTACK_ROOT/lib/lv2/lv2core.lv2 ; then + cp -R $GTKSTACK_ROOT/lib/lv2/lv2core.lv2 $APPLIB/LV2/ +fi # go through and recursively remove any .svn dirs in the bundle for svndir in `find $APPDIR -name .svn -type d`; do rm -rf $svndir done + +################################################################################ +### Mixbus plugins, etc +if test x$WITH_HARRISON_LV2 != x ; then + echo "Adding Harrison LV2s" + mkdir -p $APPLIB/LV2 + + curl -s -S --fail -# \ + -z "${CACHEDIR}/harrison_lv2s.${HARCH}.zip" \ + -o "${CACHEDIR}/harrison_lv2s.${HARCH}.zip" \ + http://www.harrisonconsoles.com/mixbus/mb3/${HARCH}/harrison_lv2s.zip + unzip -q -d "$APPLIB/LV2/" "${CACHEDIR}/harrison_lv2s.${HARCH}.zip" +fi + +if test -n "$MIXBUS"; then + echo "Adding Mixbus Channelstrip" + + mkdir -p $APPLIB/ladspa/strip/ + curl -s -S --fail -# \ + -z "${CACHEDIR}/harrison_channelstrip.${HARCH}.so" \ + -o "${CACHEDIR}/harrison_channelstrip.${HARCH}.so" \ + http://www.harrisonconsoles.com/mixbus/mb3/${HARCH}/harrison_channelstrip.so + + cp "${CACHEDIR}/harrison_channelstrip.${HARCH}.so" \ + $APPLIB/ladspa/strip/harrison_channelstrip.so + chmod +x $APPLIB/ladspa/strip/harrison_channelstrip.so +fi + +if test x$WITH_X42_LV2 != x ; then + METERS_VERSION=$(curl -s -S http://x42-plugins.com/x42/linux/x42-meters.latest.txt) + rsync -a -q --partial \ + rsync://x42-plugins.com/x42/linux/x42-meters-lv2-linux-${WARCH}-${METERS_VERSION}.zip \ + "${CACHEDIR}/x42-meters-lv2-linux-${WARCH}-${METERS_VERSION}.zip" + unzip -q -d "$APPLIB/LV2/" "${CACHEDIR}/x42-meters-lv2-linux-${WARCH}-${METERS_VERSION}.zip" + + SETBFREE_VERSION=$(curl -s -S http://x42-plugins.com/x42/linux/setBfree.latest.txt) + rsync -a -q --partial \ + rsync://x42-plugins.com/x42/linux/setBfree-lv2-linux-${WARCH}-${SETBFREE_VERSION}.zip \ + "${CACHEDIR}/setBfree-lv2-linux-${WARCH}-${SETBFREE_VERSION}.zip" + unzip -q -d "$APPLIB/LV2/" "${CACHEDIR}/setBfree-lv2-linux-${WARCH}-${SETBFREE_VERSION}.zip" + + MIDIFILTER_VERSION=$(curl -s -S http://x42-plugins.com/x42/linux/x42-midifilter.latest.txt) + rsync -a -q --partial \ + rsync://x42-plugins.com/x42/linux/x42-midifilter-lv2-linux-${WARCH}-${MIDIFILTER_VERSION}.zip \ + "${CACHEDIR}/x42-midifilter-lv2-linux-${WARCH}-${MIDIFILTER_VERSION}.zip" + unzip -q -d "$APPLIB/LV2/" "${CACHEDIR}/x42-midifilter-lv2-linux-${WARCH}-${MIDIFILTER_VERSION}.zip" + +fi +################################################################################ + + if test x$WITH_HARVID != x ; then cd $APPBIN HARVID_VERSION=$(curl -s -S http://ardour.org/files/video-tools/harvid_version.txt) @@ -566,9 +654,16 @@ fi # # Add the uninstaller # -sed -e "s/%REPLACE_PGM%/${APPNAME}/" -e "s/%REPLACE_VENDOR%/${VENDOR}/" -e "s/%REPLACE_VERSION%/${version}/" -e "s/%REPLACE_TYPE%/${BUILDTYPE}/" < uninstall.sh.in > $APPBIN/${APP_VER_NAME}.uninstall.sh +sed -e "s/%REPLACE_PGM%/${APPNAME}/" -e "s/%REPLACE_VENDOR%/${VENDOR}/" -e "s/%REPLACE_MAJOR_VERSION%/${major_version}/" -e "s/%REPLACE_VERSION%/${release_version}/" -e "s/%REPLACE_TYPE%/${BUILDTYPE}/" < uninstall.sh.in > $APPBIN/${APP_VER_NAME}.uninstall.sh chmod a+x $APPBIN/${APP_VER_NAME}.uninstall.sh +# +# Add the stage2.run script +# +sed -e "s/%REPLACE_MAJOR_VERSION%/${major_version}/;s/%REPLACE_PGM%/${APPNAME}/;s/%REPLACE_VENDOR%/${VENDOR}/;s/%REPLACE_EXE%/${EXENAME}/" < stage2.run.in > stage2.run +chmod a+x stage2.run + + #Sanity Check file if [ -e $BUILD_ROOT/tools/sanity_check/sanityCheck ]; then cp $BUILD_ROOT/tools/sanity_check/sanityCheck $APPBIN @@ -585,6 +680,8 @@ tar -cjf $APPDIR.tar.bz2 $APPDIR echo "Calculating bundle size" du -sb $APPDIR/ | awk '{print $1}' > $APPDIR.size +( cd $APPDIR ; find . ) > file_list.txt + rm -rf $APPDIR/ echo "Done."