Don't compress linux bundle, compress installer (with xz)
[ardour.git] / tools / linux_packaging / package
index 9abe586868fe8ff84eb0698d3b2a794d6b0c701d..a8dbe870cd00b939511937ee3241a79b4162636a 100755 (executable)
@@ -9,7 +9,9 @@ BUILDTYPE=""
 SINGLE_ARCH="F"
 X86_BUNDLE_OK="F"
 X86_64_BUNDLE_OK="F"
-
+GCC5ABI="F"
+MAKESELF=""
+BUILD_ROOT=../../build
 
 if [ $# -eq 0 ] ; then
        echo ""  
@@ -34,12 +36,21 @@ while [ $# -gt 0 ] ; do
        --mixbus)
                APPNAME=Mixbus ;
                shift ;;
+       --mixbus32c)
+               APPNAME=Mixbus32C ;
+               shift ;;
        --public)
                APPNAME=Ardour ;
                shift ;;
 
+       --makeself)
+               MAKESELF=`which makeself`;
+               shift ;;
+
        --singlearch) SINGLE_ARCH="T" ; shift ;;
 
+       --gcc5abi) GCC5ABI="T" ; shift ;;
+
        *)
                #catch all for unknown arguments
                echo ""
@@ -50,33 +61,23 @@ while [ $# -gt 0 ] ; do
        esac
 done
 
-
-# Figure out the Build Type
-if grep -q "DEBUG = True" ../../build/c4che/default.cache.py; then
-       DEBUG="T"
-else
-       DEBUG="F"
-fi
+. ../define_versions.sh
 
 if [ x$DEBUG = xT ]; then
        BUILDTYPE="dbg"
 fi
 
-release_version=`grep -m 1 '[^A-Za-z_]LINUX_VERSION = ' ../../wscript | awk '{print $3}' | sed "s/'//g"`
-svn_version=`grep -m 1 'svn_revision =' ../../libs/ardour/svn_revision.cc | cut -d'"' -f 2`
-
-X86_BUNDLE="${APPNAME}_x86-${release_version}_${svn_version}"
-X86_64_BUNDLE="${APPNAME}_x86_64-${release_version}_${svn_version}"
+X86_BUNDLE="${APPNAME}_x86-${release_version}"
+X86_64_BUNDLE="${APPNAME}_x86_64-${release_version}"
 
 if [ ! -z ${BUILDTYPE} ]; then
        X86_BUNDLE="${X86_BUNDLE}-${BUILDTYPE}"
        X86_64_BUNDLE="${X86_64_BUNDLE}-${BUILDTYPE}"
 fi 
 
-
-if [ ! -e ${X86_BUNDLE}.tar.bz2 ] ; then
+if [ ! -e ${X86_BUNDLE}.tar ] ; then
        echo ""
-       echo "Can't locate x86 bundle file ${X86_BUNDLE}.tar.bz2"
+       echo "Can't locate x86 bundle file ${X86_BUNDLE}.tar"
        echo ""
 elif [ ! -e ${X86_BUNDLE}.size ] ; then
        echo ""
@@ -86,9 +87,9 @@ else
        X86_BUNDLE_OK="T"
 fi
 
-if [ ! -e ${X86_64_BUNDLE}.tar.bz2 ]; then
+if [ ! -e ${X86_64_BUNDLE}.tar ]; then
        echo ""
-       echo "Can't locate x86_64 bundle file ${X86_64_BUNDLE}.tar.bz2"
+       echo "Can't locate x86_64 bundle file ${X86_64_BUNDLE}.tar"
        echo ""
 elif [ ! -e ${X86_64_BUNDLE}.size ]; then
        echo ""
@@ -122,29 +123,32 @@ fi
 if [ -z ${BUILDTYPE} ]; then
        if [ "${SINGLE_ARCH}" = "T" ]; then
                if [ "${X86_BUNDLE_OK}" = "T" ]; then
-                       PACKAGE="${APPNAME}_32bit-${release_version}_${svn_version}"
+                       PACKAGE="${APPNAME}_32bit-${release_version}"
                else
-                       PACKAGE="${APPNAME}_64bit-${release_version}_${svn_version}"
+                       PACKAGE="${APPNAME}_64bit-${release_version}"
                fi
        else
-               PACKAGE="${APPNAME}-${release_version}_${svn_version}"
+               PACKAGE="${APPNAME}-${release_version}"
        fi
 else
        if [ "${SINGLE_ARCH}" = "T" ]; then
                if [ "${X86_BUNDLE_OK}" = "T" ]; then
-                       PACKAGE="${APPNAME}_32bit-${release_version}_${svn_version}-${BUILDTYPE}"
+                       PACKAGE="${APPNAME}_32bit-${release_version}-${BUILDTYPE}"
                else
-                       PACKAGE="${APPNAME}_64bit-${release_version}_${svn_version}-${BUILDTYPE}"
+                       PACKAGE="${APPNAME}_64bit-${release_version}-${BUILDTYPE}"
                fi
        else
-               PACKAGE="${APPNAME}-${release_version}_${svn_version}-${BUILDTYPE}"
+               PACKAGE="${APPNAME}-${release_version}-${BUILDTYPE}"
        fi
 fi 
 
+if [ "$GCC5ABI" = "T" ]; then
+       PACKAGE="${PACKAGE}-gcc5"
+fi
 
 echo "Cleaning up any old package files for this build"
 #Get rid of any old packages of this same name.
-rm -f ${PACKAGE}.tar.bz2
+rm -f ${PACKAGE}.tar
 rm -rf ${PACKAGE}
 
 
@@ -152,12 +156,12 @@ echo "Creating new package dir..."
 mkdir ${PACKAGE}
 
 if [ "${X86_BUNDLE_OK}" = "T" ]; then
-       mv ${X86_BUNDLE}.tar.bz2 ${PACKAGE}
+       mv ${X86_BUNDLE}.tar ${PACKAGE}
        mv ${X86_BUNDLE}.size ${PACKAGE}/.${X86_BUNDLE}.size
 fi
 
 if [ "${X86_64_BUNDLE_OK}" = "T" ]; then
-       mv ${X86_64_BUNDLE}.tar.bz2 ${PACKAGE}
+       mv ${X86_64_BUNDLE}.tar ${PACKAGE}
        mv ${X86_64_BUNDLE}.size ${PACKAGE}/.${X86_64_BUNDLE}.size
 fi
 
@@ -165,11 +169,27 @@ cp install.sh ${PACKAGE}
 cp stage2.run ${PACKAGE}/.stage2.run
 cp README ${PACKAGE}
 
-echo "Creating tarball..."
-tar -cf ${PACKAGE}.tar ${PACKAGE}
+# gcc4/5 ABI test tool
+if [ -e $BUILD_ROOT/tools/gccabicheck/gcc-glibmm-abi-check ]; then
+       cp $BUILD_ROOT/tools/gccabicheck/gcc-glibmm-abi-check ${PACKAGE}/.gcc-glibmm-abi-check
+else
+       echo "!!!ERROR !!! gcc-glibmm-abi-check program is missing. packager will exit without being complete"
+       rm -rf ${PACKAGE}
+       rm -f stage2.run
+       exit 1
+fi
+
+if test -n "$MAKESELF"; then
+       echo "Creating self-extracting installer"
+       $MAKESELF --xz --complevel 9 ${PACKAGE}/ ${PACKAGE}.run ${APPNAME} ./install.sh
+else
+       echo "Creating tarball..."
+       tar -cf ${PACKAGE}.tar ${PACKAGE}
+fi
 
 echo "Clean up"
 rm -rf ${PACKAGE}
+rm -f stage2.run
 
 echo ""
 echo "Done"