X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=tools%2Flinux_packaging%2Fbuild;h=7d80644ac783026002f49ba6cc139974ff154eb2;hb=baf6f73c3415ee4b562a4cd5bc685f0fd6d21875;hp=caadd8f2fd5c53d6f21fca2cd81dc26600c00f59;hpb=eabf3c31ed5337c704a0433cf2b217819fb2ffba;p=ardour.git diff --git a/tools/linux_packaging/build b/tools/linux_packaging/build index caadd8f2fd..7d80644ac7 100755 --- a/tools/linux_packaging/build +++ b/tools/linux_packaging/build @@ -14,8 +14,14 @@ ARDOURSTACK_ROOT=$HOME/a3/inst # the waf build tree to use when copying built/generated files BUILD_ROOT=../../build +# where harvid and xjadeo binaries are cached +if test -z "$CACHEDIR" -o ! -d "$CACHEDIR"; then + CACHEDIR=`pwd` +fi + MIXBUS= WITH_LADSPA=0 +WITH_HARVID= STRIP=all PRINT_SYSDEPS= WITH_NLS= @@ -23,6 +29,7 @@ EXTERNAL_JACK= VENDOR=Ardour ; BUILDTYPE="" + if [ $# -eq 0 ] ; then echo "" echo "ERROR - Please specify build type" @@ -70,6 +77,7 @@ while [ $# -gt 0 ] ; do --strip) STRIP=$2 ; shift ; shift ;; --sysdeps) PRINT_SYSDEPS=1; shift ;; --nls) WITH_NLS=1 ; shift ;; + --harvid) WITH_HARVID=1 ; shift ;; *) #catch all for unknown arguments @@ -87,10 +95,14 @@ if test x$STRIP != xall -a x$STRIP != xnone -a x$STRIP != xsome ; then exit 1 fi -release_version=`grep -m 1 '^VERSION' ../../wscript | awk '{print $3}' | sed "s/'//g"` -svn_version=`grep -m 1 'svn_revision =' ../../libs/ardour/svn_revision.cc | cut -d'"' -f 2` -echo "Version is $release_version / $svn_version" -info_string="$release_version/$svn_version built on `hostname` by `whoami` on `date`" +. ../define_versions.sh + +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 @@ -99,11 +111,13 @@ case `uname -m` in echo "Architecture is x86" ARCH='x86' ARCH_BITS='32-bit' + MULTIARCH='i386-linux-gnu' ;; x86_64|amd64|AMD64) echo "Architecture is x86_64" ARCH='x86_64' ARCH_BITS='64-bit' + MULTIARCH='x86_64-linux-gnu' ;; *) echo "" @@ -113,13 +127,6 @@ case `uname -m` in ;; esac -# Figure out the Build Type -if grep -q "DEBUG = True" ../../build/c4che/default.cache.py; then - DEBUG="T" -else - DEBUG="F" -fi - if [ x$DEBUG = xT ]; then BUILDTYPE="dbg" if [ x$STRIP = xall ] ; then @@ -131,11 +138,11 @@ fi # setup directory structure if [ -z "${BUILDTYPE}" ]; then - APPDIR=${APPNAME}_${ARCH}-${release_version}_${svn_version} - APP_VER_NAME=${APPNAME}-${release_version}_${svn_version} + APPDIR=${APPNAME}_${ARCH}-${release_version} + APP_VER_NAME=${APPNAME}-${release_version} else - APPDIR=${APPNAME}_${ARCH}-${release_version}_${svn_version}-${BUILDTYPE} - APP_VER_NAME=${APPNAME}-${release_version}_${svn_version}-${BUILDTYPE} + APPDIR=${APPNAME}_${ARCH}-${release_version}-${BUILDTYPE} + APP_VER_NAME=${APPNAME}-${release_version}-${BUILDTYPE} fi APPBIN=$APPDIR/bin @@ -147,6 +154,7 @@ Shared=$APPDIR/share Plugins=$APPLIB/plugins Surfaces=$APPLIB/surfaces Panners=$APPLIB/panners +Backends=$APPLIB/backends Modules=$Libraries/modules Loaders=$Libraries/loaders @@ -157,6 +165,7 @@ Locale=$Shared/locale MidiMaps=$Shared/midi_maps PatchFiles=$Shared/patchfiles MackieControl=$Shared/mcp +VFork=$Libraries/vfork if [ x$PRINT_SYSDEPS != x ] ; then # @@ -194,9 +203,10 @@ mkdir -p $PatchFiles mkdir -p $MackieControl mkdir -p $ExportFormats mkdir -p $Panners +mkdir -p $Backends mkdir -p $Templates -mkdir -p $Shared/templates mkdir -p $Shared/doc +mkdir -p $VFork # maybe set variables ENVIRONMENT=environment @@ -224,8 +234,7 @@ echo export 'PATH=/usr/local/bin:/opt/bin:$PATH' >> $ENVIRONMENT sed -e "/^%ENV%/r $ENVIRONMENT" -e '/^%ENV%/d' -e 's/%VER%/'"${release_version}"'/' < ardour.sh.in > $APPBIN/ardour3 rm $ENVIRONMENT && chmod 775 $APPBIN/ardour3 -# the 3.0 here is not the same as "release-version" because the latter may include "-betaN" etc. -MAIN_EXECUTABLE=ardour-3.0 +MAIN_EXECUTABLE=ardour-${release_version} echo "Copying ardour executable ...." cp $BUILD_ROOT/gtk2_ardour/$MAIN_EXECUTABLE $APPBIN @@ -241,12 +250,21 @@ if test x$WITH_NLS != x ; then echo "I hope you remembered to run scons msgupdate!" LINGUAS= - for dl in gtk2_ardour libs/ardour libs/gtkmm2ext ; do - files=`find ../../$dl -name "*.mo"` + for pkg in gtk2_ardour libs/ardour libs/gtkmm2ext ; do + files=`find ../../$pkg -name "*.mo"` + + # + # the package name is appended with a number so that + # it can be parallel installed during a regular install + # with older (and newer) versions. it is just the major + # number of the release (i.e. leading digits) + # + + vsuffix=`echo $release_version | sed 's/^\([0-9][0-9]*\).*/\1/'` if [ -z "$files" ]; then echo "" - echo "!!!! WARNING !!!! - Did not find any .mo files in ../../$dl" + echo "!!!! WARNING !!!! - Did not find any .mo files in ../../$pkg" echo "" fi @@ -255,7 +273,8 @@ if test x$WITH_NLS != x ; then echo $file lang=`basename $file | sed 's/\.mo//'` mkdir -p $Locale/$lang/LC_MESSAGES - cp $file $Locale/$lang/LC_MESSAGES/`basename $dl` + cp $file $Locale/$lang/LC_MESSAGES/`basename $pkg`$vsuffix.mo + echo copy $file to $Locale/$lang/LC_MESSAGES/`basename $pkg`$vsuffix.mo if echo $LINGUAS | grep $lang >/dev/null 2>&1 ; then : else @@ -265,7 +284,7 @@ if test x$WITH_NLS != x ; then done GTK_MESSAGES="atk10.mo gdk-pixbuf.mo gtk20-properties.mo gtk20.mo atk10.mo glib20.mo" - LOCALEROOT=/usr/share/locale + LOCALEROOT=$GTKSTACK_ROOT/share/locale for l in $LINGUAS ; do echo "Copying GTK i18n files for $l..." @@ -291,7 +310,7 @@ fi cp -R $GTKSTACK_ROOT/etc/* $Etc echo "Copying all Pango modules ..." -cp -R $GTKSTACK_ROOT/lib/pango/1.6.0/modules/*.so $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 @@ -299,21 +318,26 @@ cp -R $GTKSTACK_ROOT/lib/gdk-pixbuf-2.0/2.10.0/loaders/*.so $Loaders cat > pangorc < $Etc/pango.modules.in +env PANGO_RC_FILE=pangorc $GTKSTACK_ROOT/bin/pango-querymodules | sed "s?$GTKSTACK_ROOT/lib/pango/1.8.0/?@ROOTDIR@/?" > $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/clearlooks +# this one is special - we will set GTK_PATH to $Libraries/gtkengines -echo "Copying clearlooks ..." +GTK_ENGINE_DIR=$Libraries/gtkengines/engines +mkdir -p $GTK_ENGINE_DIR + +echo "Copying GTK engines ..." cp $BUILD_ROOT/libs/clearlooks-newer/libclearlooks.so $Libraries -mkdir -p $Libraries/clearlooks/engines -(cd $Libraries/clearlooks/engines && ln -s ../../libclearlooks.so . ) +(cd $GTK_ENGINE_DIR && ln -s ../../libclearlooks.so . ) + +cp $GTKSTACK_ROOT/lib/gtk-2.0/2.10.0/engines/libpixmap.so $Libraries +(cd $GTK_ENGINE_DIR && ln -s ../../libpixmap.so . ) # LADSPA if test x$WITH_LADSPA != x ; then @@ -351,11 +375,11 @@ for x in $BUILD_ROOT/../mcp/*.device $BUILD_ROOT/../mcp/*.profile ; do done # Templates -for f in $BUILD_ROOT/../templates/* ; do - if [ -d "$f" ] ; then - echo Template: $f ; cp -r "$f" $Templates ; - fi -done +#for f in $BUILD_ROOT/../templates/* ; do +# if [ -d "$f" ] ; then +# echo Template: $f ; cp -r "$f" $Templates ; +# fi +#done # ExportFormats # got to be careful with names here @@ -366,14 +390,31 @@ done # Panners cp $BUILD_ROOT/libs/panners/*/lib*.so* $Panners +# Backends +for backend in jack 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 +# 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) +cp $BUILD_ROOT/libs/fst/ardour-vst-scanner* $APPLIB || true + +# vfork wrapper +cp $BUILD_ROOT/libs/vfork/ardour-exec-wrapper $VFork + +# ALSA device reservation tool (if available) +cp $BUILD_ROOT/libs/ardouralsautil/ardour-request-device $APPLIB/ || true + 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 echo $OURLIBS${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH} @@ -432,6 +473,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 @@ -485,13 +528,19 @@ echo "Copying other stuff to $APPDIR ..." #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 ../../system_config $Etc/system_config +cp $BUILD_ROOT/gtk2_ardour/ui_light.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/ui_light.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/light_fonts.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/dark_fonts.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/light_styles.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/dark_styles.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/widgets.rc $Etc +cp $BUILD_ROOT/gtk2_ardour/ui_default.conf $Etc +cp $BUILD_ROOT/gtk2_ardour/ui_default.conf $Etc/ardour3_ui.conf # these are copied straight from the 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 ../../gtk2_ardour/step_editing.bindings $Etc cp ../../gtk2_ardour/mixer.bindings $Etc @@ -510,16 +559,45 @@ fi # share stuff cp -R ../../gtk2_ardour/splash.png $Shared +cp -R ../../gtk2_ardour/small-splash.png $Shared +cp -R ../../gtk2_ardour/ArdourMono.ttf $Shared + +# install bundled LV2s to /lib/LV2/ +cp -R $BUILD_ROOT/libs/LV2 $APPLIB/ # 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 +if test x$WITH_HARVID != x ; then + cd $APPBIN + HARVID_VERSION=$(curl -s -S http://ardour.org/files/video-tools/harvid_version.txt) + XJADEO_VERSION=$(curl -s -S http://ardour.org/files/video-tools/xjadeo_version.txt) + + rsync -Pa \ + rsync://ardour.org/video-tools/harvid-${MULTIARCH}-${HARVID_VERSION}.tgz \ + "$CACHEDIR/harvid-${MULTIARCH}-${HARVID_VERSION}.tgz" + + rsync -Pa \ + rsync://ardour.org/video-tools/xjadeo-${MULTIARCH}-${XJADEO_VERSION}.tgz \ + "$CACHEDIR/xjadeo-${MULTIARCH}-${XJADEO_VERSION}.tgz" + + tar -x -z \ + --exclude=README --exclude=harvid.1 --strip-components=1 \ + -f "$CACHEDIR/harvid-${MULTIARCH}-${HARVID_VERSION}.tgz" || exit 1 + + tar -x -z \ + --exclude=README --exclude=xjadeo.1 --strip-components=1 \ + -f "$CACHEDIR/xjadeo-${MULTIARCH}-${XJADEO_VERSION}.tgz" || exit 1 + mv xjadeo xjremote + cd - +fi + # # Add the uninstaller # -sed -e "s/%REPLACE_PGM%/${APPNAME}/" -e "s/%REPLACE_VENDOR%/${VENDOR}/" -e "s/%REPLACE_VERSION%/${release_version}/" -e "s/%REPLACE_BUILD%/${svn_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_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 #Sanity Check file