Re-use locations when setting location list state, so that selected locations are...
[ardour.git] / tools / linux_packaging / build
index 4a145ee7cba394988ffa763bc8a6ca19e8ff473d..2cef0bb04587f58840a98e35cf3b4aad0b294aaa 100755 (executable)
@@ -5,14 +5,20 @@
 . ./buildenv
 
 # script for pulling together a Linux app bundle.
+#
+# This will create a bundle for a single architecture.
+# Execute this scirpt on both x86 and x86_64 and then use
+# package to merge the 2 bundles into a final package with the
+# installer.
 
 MIXBUS=
-INTERNAL_JACK=1
 WITH_LADSPA=0
-STRIP=1
+STRIP=all
 PRINT_SYSDEPS=
 WITH_NLS=
 EXTERNAL_JACK=
+VENDOR=Ardour ;
+BUILDTYPE=""
 
 if [ $# -eq 0 ] ; then
        echo ""  
@@ -34,25 +40,23 @@ while [ $# -gt 0 ] ; do
        --mixbus)
                MIXBUS=1; 
                WITH_NLS=1 ; 
-               INTERNAL_JACK=; 
                WITH_LADSPA=; 
-               STRIP= ; 
+               STRIP=all
                APPNAME=Mixbus ;
+                VENDOR=Harrison ;
                shift ;;
        --public)
                WITH_NLS=1 ; 
-               INTERNAL_JACK=; 
                WITH_LADSPA=; 
-               STRIP= ; 
+               STRIP=all ; 
                APPNAME=Ardour ;
                shift ;;
        --allinone)
                WITH_NLS= ; 
-               INTERNAL_JACK=1; 
                WITH_LADSPA=1; 
-               STRIP= 
+               STRIP=all
                shift ;;
-       --test) INTERNAL_JACK=; WITH_LADSPA=; STRIP= ; shift ;;
+       --test) WITH_LADSPA=; STRIP= ; shift ;;
 
        #
        # specific build flags
@@ -60,10 +64,9 @@ while [ $# -gt 0 ] ; do
 
        --nojack) INTERNAL_JACK= ; shift ;;
        --noladspa) WITH_LADSPA= ; shift ;;
-       --nostrip) STRIP= ; shift ;;
+       --strip) STRIP=$2 ; shift ; shift ;;
        --sysdeps) PRINT_SYSDEPS=1; shift ;;
        --nls) WITH_NLS=1 ; shift ;;
-       --external_jack) EXTERNAL_JACK=$2; shift ; shift ;;
 
        *)
                #catch all for unknown arguments
@@ -75,8 +78,10 @@ while [ $# -gt 0 ] ; do
        esac
 done
 
-if [ x$EXTERNAL_JACK != x -a x$INTERNAL_JACK != x ] ; then
-       echo "It makes no sense to package JACK internally and externally. Please pick one."
+if test x$STRIP != xall -a x$STRIP != xnone -a x$STRIP != xsome ; then
+    echo "Unknown strip option \"$STRIP\""
+    echo "Legal values are: all, none, some"
+    exit 1
 fi
 
 release_version=`grep -m 1 '^VERSION' ../../wscript | awk '{print $3}' | sed "s/'//g"`
@@ -105,13 +110,35 @@ 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
+        echo "A debug build with --strip all makes no sense - STRIP reset to \"some\""
+        STRIP=some
+    fi
+fi
+
 # the waf build tree to use when copying built/generated files
 
 BUILD_ROOT=../../build/default
 
 # setup directory structure
 
-APPDIR=${APPNAME}_${ARCH}-${release_version}_${svn_version}
+if [ -z "${BUILDTYPE}" ]; then
+       APPDIR=${APPNAME}_${ARCH}-${release_version}_${svn_version}
+       APP_VER_NAME=${APPNAME}-${release_version}_${svn_version}
+else
+       APPDIR=${APPNAME}_${ARCH}-${release_version}_${svn_version}-${BUILDTYPE}
+       APP_VER_NAME=${APPNAME}-${release_version}_${svn_version}-${BUILDTYPE}
+fi
+
 APPBIN=$APPDIR/bin
 APPLIB=$APPDIR/lib
 Libraries=$APPLIB
@@ -120,7 +147,9 @@ Shared=$APPDIR/share
 Plugins=$APPLIB/plugins
 Surfaces=$APPLIB/surfaces
 Panners=$APPLIB/panners
+ExportFormats=$Shared/export
 Locale=$Shared/locale
+MidiMaps=$Shared/midi_maps
 Modules=$Libraries/modules
 Loaders=$Libraries/loaders
 
@@ -156,8 +185,11 @@ mkdir -p $Loaders
 mkdir -p $Shared
 mkdir -p $Locale
 mkdir -p $Surfaces
+mkdir -p $MidiMaps
+mkdir -p $ExportFormats
 mkdir -p $Panners
 mkdir -p $Shared/templates
+mkdir -p $Shared/doc
 
 # maybe set variables
 ENVIRONMENT=environment
@@ -170,8 +202,8 @@ if test x$MIXBUS != x ; then
        # current default for MIXBUS version is US keyboard layout without a keypad
        #
        echo export ARDOUR_KEYBOARD_LAYOUT=us-nokeypad >> $ENVIRONMENT
-       echo export ARDOUR_UI_CONF=ardour2_ui.conf >> $ENVIRONMENT
-       echo export ARDOUR2_UI_RC=ardour2_ui_dark.rc >> $ENVIRONMENT
+       echo export ARDOUR_UI_CONF=ardour3_ui.conf >> $ENVIRONMENT
+       echo export ARDOUR3_UI_RC=ardour3_ui_dark.rc >> $ENVIRONMENT
 fi
 
 #
@@ -183,17 +215,20 @@ 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/ardour2
-rm $ENVIRONMENT && chmod 775 $APPBIN/ardour2
-MAIN_EXECUTABLE=ardour-$release_version
+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
+MAIN_EXECUTABLE=ardour-3.0
 
 echo "Copying ardour executable ...."
-cp ../../gtk2_ardour/$MAIN_EXECUTABLE $APPBIN
-if test x$STRIP != x ; then
+cp $BUILD_ROOT/gtk2_ardour/$MAIN_EXECUTABLE $APPBIN
+if test x$STRIP = xall ; then
        strip $APPBIN/$MAIN_EXECUTABLE
 fi
 
 # copy locale files
+# note that at present(feb 2011), the .mo files end up in the source tree which is
+# not really as it should be.
 if test x$WITH_NLS != x ; then
        echo "NLS support ..."
        echo "I hope you remembered to run scons msgupdate!"
@@ -257,9 +292,9 @@ GTKROOT=`pkg-config --libs-only-L gtk+-2.0 | sed -e "s/-L//" -e "s/[[:space:]]//
 if [ ! -z "$GTKROOT" ]; then
        echo "Found GTKROOT using pkg-config"
 elif [ -d /usr/lib/gtk-2.0 ]; then
-       GTKROOT="/usr/lib/gtk-2.0"
+       GTKROOT="/usr/lib"
 elif [ -d /usr/local/lib/gtk-2.0 ]; then
-       GTKROOT="/usr/local/lib/gtk-2.0"
+       GTKROOT="/usr/local/lib"
 else
        echo ""
        echo "!!! ERROR !!! - Unable to locate gtk-2.0 directory. Packager will exit"
@@ -272,7 +307,7 @@ versionDir=`ls ${GTKROOT}/gtk-2.0/ | grep "[0-9]*\.[0-9]*\.[0-9]*"`
 
 num=0
 for name in $versionDir ; do
-       let "num += 1"
+    num=$(($num + 1))
 done
 
 if [ $num -eq 1 ]; then
@@ -291,9 +326,9 @@ PANGOROOT=`pkg-config --libs-only-L pango | sed -e "s/-L//" -e "s/[[:space:]]//g
 if [ ! -z "$PANGOROOT" ]; then
        echo "Found PANGOROOT using pkg-config"
 elif [ -d /usr/lib/pango ]; then
-       PANGOROOT="/usr/lib/pango"
+       PANGOROOT="/usr/lib"
 elif [ -d /usr/local/lib/pango ]; then
-       PANGOROOT="/usr/local/lib/pango"
+       PANGOROOT="/usr/local/lib"
 else
        echo ""
        echo "!!! ERROR !!! - Unable to locate pango directory. Packager will exit"
@@ -306,7 +341,7 @@ versionDir=`ls ${PANGOROOT}/pango/ | grep "[0-9]*\.[0-9]*\.[0-9]*"`
 
 num=0
 for name in $versionDir ; do
-       let "num += 1"
+       num=$(($num + 1))
 done
 
 if [ $num -eq 1 ]; then
@@ -345,7 +380,7 @@ if [ -z ${GDKPIXBUFLIB} ]; then
 
        num=0
        for name in $versionDir ; do
-               let "num += 1"
+           num=$(($num + 1))
        done
 
        if [ $num -eq 1 ]; then
@@ -373,18 +408,18 @@ gdk-pixbuf-query-loaders | sed "s?$GDKPIXBUFLIB/?@ROOTDIR@/?" > $Etc/gdk-pixbuf.
 # We sort of rely on clearlooks, so include a version
 # this one is special - we will set GTK_PATH to $Libraries/clearlooks
 
-#if [ ! -e ${GTKLIB}/engines/libclearlooks.so ]; then
-#      echo ""
-#      echo "!!! ERROR !!! - not able to locate libclearlooks.so"
-#      echo ""
-#      echo "Packager with exit"
-#      exit 1
-#fi
+if [ ! -e ${GTKLIB}/engines/libclearlooks.so ]; then
+       echo ""
+       echo "!!! ERROR !!! - not able to locate libclearlooks.so"
+       echo ""
+       echo "Packager with exit"
+       exit 1
+fi
 
-#echo "Copying clearlooks ..."
-#cp ${GTKLIB}/engines/libclearlooks.so $Libraries
-#mkdir -p $Libraries/clearlooks/engines
-#(cd $Libraries/clearlooks/engines && ln -s ../../libclearlooks* libclearlooks.so )
+echo "Copying clearlooks ..."
+cp ${GTKLIB}/engines/libclearlooks.so $Libraries
+mkdir -p $Libraries/clearlooks/engines
+(cd $Libraries/clearlooks/engines && ln -s ../../libclearlooks* libclearlooks.so )
 
 # LADSPA
 if test x$WITH_LADSPA != x ; then
@@ -399,20 +434,37 @@ if test x$WITH_LADSPA != x ; then
        fi
 fi
 
-# XXX STILL NEED TO DO PANNERS FOR TRUNK
-cp ../../libs/surfaces/*/libardour_*.so* $Surfaces
+# Control Surfaces
+cp $BUILD_ROOT/libs/surfaces/*/libardour*.so* $Surfaces
 # hack ... move libardour_cp back into Libraries
-mv $Surfaces/libardour_cp.so* $Libraries
+mv $Surfaces/libardourcp.so* $Libraries
+
+# MidiMaps
+# got to be careful with names here
+for x in $BUILD_ROOT/../../midi_maps/*.map ; do
+    cp "$x" $MidiMaps
+    echo Copied MIDI map $x 
+done
+
+# ExportFormats
+# got to be careful with names here
+for x in $BUILD_ROOT/../../export/*.preset $BUILD_ROOT/../../export/*.format ; do
+    cp "$x" $ExportFormats
+done
+
+# Panners
+cp $BUILD_ROOT/libs/panners/*/lib*.so* $Panners
 
 # VAMP plugins that we use
-cp ../../libs/vamp-plugins/libardourvampplugins.so* $Libraries
+cp $BUILD_ROOT/libs/vamp-plugins/libardourvampplugins.so* $Libraries
 
-OURLIBDIR=../../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=$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/qm-dsp
 
 echo $OURLIBS${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}
 
 checkedIdx=0
+deplibs=
 
 while [ true ] ; do 
        missing=false
@@ -431,7 +483,7 @@ while [ true ] ; do
                        fi
                done
                depCheckedList[$checkIdx]=$file
-               let "checkIdx += 1"
+               checkIdx=$(($checkIdx + 1))
                
                # do not include libjack
                deps=`LD_LIBRARY_PATH=$OURLIBS${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH} ldd $file | awk '{print $3}'`
@@ -467,12 +519,16 @@ while [ true ] ; do
                        if ! test -f $Libraries/$base; then
                                parent=$(basename ${file})
                                if echo $dep | grep -sq '^libs' ; then
-                                       echo "Copying dependant lib ../../$dep    (required by ${parent})"
-                                       cp ../../$dep $Libraries
+                                       echo "Copying dependant lib $BUILD_ROOT/$dep    (required by ${parent})"
+                                       cp $BUILD_ROOT/$dep $Libraries
                                else
                                        echo "Copying dependant lib $dep    (required by ${parent})"
                                        cp $dep $Libraries
                                fi
+                                if echo $dep | grep -sq '^/' ; then
+                                    # absolute path, candidate for stripping
+                                    deplibs="$deplibs $base"
+                                fi
                                missing=true
                        fi
                done
@@ -485,8 +541,15 @@ done
 echo
 
 # strip libraries
-echo Stripping libraries
-find $APPLIB/ -name "*.so*" | xargs strip
+if test x$STRIP = xall ; then
+    echo Stripping all libraries
+    find $APPLIB/ -name "*.so*" | xargs strip
+elif test x$STRIP = xsome ; then
+    echo Stripping dependent libraries
+    for l in $deplibs ; do
+        strip $APPLIB/$l
+    done
+fi
 find $APPLIB/ -name "*.so*" | xargs chmod a+rx
 
 echo "Copying other stuff to $APPDIR  ..."
@@ -496,8 +559,7 @@ echo "Copying other stuff to $APPDIR  ..."
 cp $BUILD_ROOT/gtk2_ardour/mnemonic-us.bindings  $Etc
 cp $BUILD_ROOT/gtk2_ardour/ardour.menus $Etc
 cp $BUILD_ROOT/ardour_system.rc $Etc/ardour_system.rc
-# temporarily unavailable
-#cp $BUILD_ROOT/gtk2_ardour/ardour3_ui_light.rc $Etc
+cp $BUILD_ROOT/gtk2_ardour/ardour3_ui_light.rc $Etc
 cp $BUILD_ROOT/gtk2_ardour/ardour3_ui_dark.rc $Etc
 
 # these are copied straight from the source tree
@@ -526,34 +588,29 @@ for svndir in `find $APPDIR -name .svn -type d`; do
        rm -rf $svndir
 done
 
+#
+# 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
+chmod a+x $APPBIN/${APP_VER_NAME}.uninstall.sh
+
 #Sanity Check file
 if [ -e $BUILD_ROOT/tools/sanity_check/sanityCheck ]; then
-       cp $BUILD_ROOT/tools/sanity_check/sanityCheck $APPDIR
+       cp $BUILD_ROOT/tools/sanity_check/sanityCheck $APPBIN
 else
        echo "!!!ERROR !!! sanityCheck program is missing. packager will exit without being complete"
        exit 1
 fi
 
-#
-# and now ... the final package
-# 
-
-if [ x$MIXBUS != x ] ; then
-
-       # Mixbus packaging
-
-       echo "Creating Mixbus packaging directory"
-       cp MixBus_Install_QuickStart.pdf "$APPDIR/Mixbus Install & Quick Start Guide.pdf"
-       
-       if [ -x $EXTERNAL_JACK != x ] ; then
-               cp $EXTERNAL_JACK $PRODUCT_PKG_DIR
-       fi
-fi
-
 echo "Building tarball ..."
 
 rm -f $APPDIR.tar.bz2
 tar -cjf $APPDIR.tar.bz2 $APPDIR
 
+echo "Calculating bundle size"
+du -sb $APPDIR/  | awk '{print $1}' > $APPDIR.size
+
+rm -rf $APPDIR/
+
 echo "Done."