diff --git a/packaging/ubuntu/make-package.sh b/packaging/ubuntu/make-package.sh index 2dbf45f5b..fdb5b08ed 100644 --- a/packaging/ubuntu/make-package.sh +++ b/packaging/ubuntu/make-package.sh @@ -1,17 +1,38 @@ #!/bin/bash -e -# start from the directory above the combined subsurface & subsurface/libdivecomputer directory +# start from the directory above the subsurface directory # -# in order to be able to make changes to the debian/* files without changing the source -# this script assumes that the debian/* files plus a separate debian.changelog are in -# this directory as well - this makes testing builds on launchpad easier -# for most people all it should take is to run -# cp -a packaging/ubuntu/debian . +# we need to build the google maps plugin which is not part of our sources, so let's make sure +# it is included in our source tar file # -if [[ $(pwd | grep "subsurface$") || ! -d subsurface || ! -d subsurface/libdivecomputer || ! -d subsurface/libgit2 ]] ; then +# also, for bionic we need newer versions of libgit2 than what ships with the +# distro, so let's just use libgit2 1.0 everywhere + +if [[ $(pwd | grep "subsurface$") || ! -d subsurface || ! -d subsurface/libdivecomputer ]] ; then echo "Please start this script from the folder ABOVE the subsurface source directory" - echo "which includes libdivecomputer and libgit2 as subdirectories)." exit 1; fi +if [[ ! -d googlemaps ]] ; then + echo "Please make sure you have the current master of git://github.com/Subsurface-divelog/googlemaps" + echo "checked out in parallel to the Subsurface directory" + exit 1; +fi + +if [[ ! -d libgit2 ]] ; then + echo "Please make sure you have libgit2 1.0 from git://github.com/libgit2/libgit2" + echo "checked out in parallel to the Subsurface directory" + exit 1; +fi + +if [[ "$1" = "-obs" ]] ; then + echo "Also pushing update to OBS" + OBS="1" +fi + +# ensure that the libdivecomputer module is there and current +cd subsurface +git submodule init +git submodule update +cd - GITVERSION=$(cd subsurface ; git describe --abbrev=12 | sed -e 's/-g.*$// ; s/^v//') GITREVISION=$(echo $GITVERSION | sed -e 's/.*-// ; s/.*\..*//') @@ -19,56 +40,79 @@ VERSION=$(echo $GITVERSION | sed -e 's/-/./') GITDATE=$(cd subsurface ; git log -1 --format="%at" | xargs -I{} date -d @{} +%Y-%m-%d) LIBDCREVISION=$(cd subsurface/libdivecomputer ; git rev-parse --verify HEAD) -# -# +if [[ "$GITVERSION" = "" ]] ; then + SUFFIX=".release" +else + SUFFIX=".daily" +fi + echo "building Subsurface" $VERSION "with libdivecomputer" $LIBDCREVISION -# + +# we put all of the files into the distrobuilds directory in order not to clutter the 'src' directory +mkdir -p distrobuilds +cd distrobuilds + if [[ ! -d subsurface_$VERSION ]]; then mkdir subsurface_$VERSION - if [[ "x$GITREVISION" != "x" ]] ; then + if [[ "$GITREVISION" != "" ]] ; then rm -f subsurfacedaily-$VERSION ln -s subsurface_$VERSION subsurfacedaily-$VERSION else - rm -f subsurfacebeta-$VERSION - ln -s subsurface_$VERSION subsurfacebeta-$VERSION + rm -f subsurface-$VERSION + ln -s subsurface_$VERSION subsurface-$VERSION fi - # - # echo "copying sources" - # - (cd subsurface ; tar cf - . ) | (cd subsurface_$VERSION ; tar xf - ) + + (cd ../subsurface ; tar cf - . ) | (cd subsurface_$VERSION ; tar xf - ) cd subsurface_$VERSION; - rm -rf .git libdivecomputer/.git libgit2/.git + cp -a ../../googlemaps . + cp -a ../../libgit2 . + + # now make sure we have libgit2 1.0 + cd libgit2 + git fetch + git checkout v1.0.0 + cd .. + rm -rf .git libdivecomputer/.git googlemaps/.git build build-mobile libdivecomputer/build googlemaps/build libgit2/.git libgit2/build echo $GITVERSION > .gitversion echo $GITDATE > .gitdate echo $LIBDCREVISION > libdivecomputer/revision - # dh_make --email dirk@hohndel.org -c gpl2 --createorig --single --yes -p subsurface_$VERSION - # rm debian/*.ex debian/*.EX debian/README.* - # - # - echo "creating source tar file for OBS and Ununtu PPA" - # - if [[ "x$GITREVISION" != "x" ]] ; then - (cd .. ; tar ch subsurfacedaily-$VERSION | xz > home:Subsurface-Divelog/Subsurface-daily/subsurface-$VERSION.orig.tar.xz) & - else - (cd .. ; tar ch subsurfacebeta-$VERSION | xz > home:Subsurface-Divelog/Subsurface-beta/subsurface-$VERSION.orig.tar.xz) & + + if [[ "$OBS" = "1" ]]; then + # oops, this isn't really for Debian/Ubuntu... it just creates corresponding source tar files for + # the Open Build Service to create SUSE and Fedora packages while we are at it + if [[ "$GITREVISION" != "" ]] ; then + (cd .. ; tar ch subsurfacedaily-$VERSION | xz > home:Subsurface-Divelog/Subsurface-daily/subsurface-$VERSION.orig.tar.xz) & + else + (cd .. ; tar ch subsurface-$VERSION | xz > home:Subsurface-Divelog/Subsurface/subsurface-$VERSION.orig.tar.xz) & + fi fi + + echo "creating source tar file for OBS and Ununtu PPA" + tar cf - . | xz > ../subsurface_$VERSION.orig.tar.xz else echo "using existing source tree" cd subsurface_$VERSION fi -# -# -echo "preparint the debian directory" -# -export DEBEMAIL=dirk@hohndel.org + + +echo "preparing the debian directory" + +# this uses my (Dirk's) email address by default... simply set that variable in your +# environment prior to starting the script +test -z $DEBEMAIL && export DEBEMAIL=dirk@hohndel.org + +# copy over the debian files and allow maintaining a release and daily changelog files rm -rf debian mkdir -p debian -cp -a ../debian . -cp ../debian.changelog debian/changelog +cp -a ../../subsurface/packaging/ubuntu/debian . +# start with the bundled dummy changelog, but use our last one if it exists +test -f ../changelog$SUFFIX && cp ../changelog$SUFFIX debian/changelog + +# pick a new revision number rev=0 while [ $rev -le "99" ] do @@ -77,19 +121,21 @@ rev=$(($rev+1)) break fi done -if [[ "$RELEASE" = "1" ]] ; then - dch -v $VERSION-$rev~xenial -D xenial -M -m "Next release build - please check https://subsurface-divelog.org/category/news/ for details" + +# we need to do this for each Ubuntu release we support - right now the oldest is 16.04/Xenial +if [[ "$GITREVISION" = "" ]] ; then + dch -v $VERSION-$rev~bionic -D bionic -M -m "Next release build - please check https://subsurface-divelog.org/category/news/ for details" else - dch -v $VERSION-$rev~xenial -D xenial -M -m "next daily build" + dch -v $VERSION-$rev~bionic -D bionic -M -m "next daily build" fi -mv ~/src/debian.changelog ~/src/debian.changelog.previous -cp debian/changelog ~/src/debian.changelog + +cp debian/changelog ../changelog$SUFFIX debuild -S #create builds for the newer Ubuntu releases that Launchpad supports -rel=xenial -others="artful bionic" +rel=bionic +others="eoan focal" for next in $others do sed -i "s/${rel}/${next}/g" debian/changelog @@ -99,24 +145,32 @@ done cd .. -if [[ "$1x" = "postx" ]] ; then - # daily vs. beta vs. release - if [[ "x$GITREVISION" == "x" ]] ; then - # this is a beta or a release; assume beta for now and deal with release later :-) - dput ppa:subsurface/subsurface-beta subsurface_$VERSION-$rev~*.changes - cd home:Subsurface-Divelog/Subsurface-beta - osc rm $(ls subsurface*.tar.xz | grep -v $VERSION) - osc add subsurface-$VERSION.orig.tar.xz - sed -i "s/%define latestVersion.*/%define latestVersion $VERSION/" subsurfacebeta.spec - sed -i "s/%define gitVersion .*/%define gitVersion 0/" subsurfacebeta.spec - osc commit -m "next beta build" +if [[ "$1" = "post" ]] ; then + # daily vs. release + if [[ "$GITREVISION" == "" ]] ; then + # this is a release + dput ppa:subsurface/subsurface subsurface_$VERSION-$rev~*.changes + + if [[ "$OBS" = "1" ]]; then + # more stuff for OBS / SUSE / Fedora + cd home:Subsurface-Divelog/Subsurface + osc rm $(ls subsurface*.tar.xz | grep -v $VERSION) + osc add subsurface-$VERSION.orig.tar.xz + sed -i "s/%define latestVersion.*/%define latestVersion $VERSION/" subsurface.spec + sed -i "s/%define gitVersion .*/%define gitVersion 0/" subsurface.spec + osc commit -m "next release build" + fi else dput ppa:subsurface/subsurface-daily subsurface_$VERSION-$rev~*.changes - cd home:Subsurface-Divelog/Subsurface-daily - osc rm $(ls subsurface*.tar.xz | grep -v $VERSION) - osc add subsurface-$VERSION.orig.tar.xz - sed -i "s/%define latestVersion.*/%define latestVersion $VERSION/" subsurfacedaily.spec - sed -i "s/%define gitVersion .*/%define gitVersion $GITREVISION/" subsurfacedaily.spec - osc commit -m "next daily build" + + if [[ "$OBS" = "1" ]]; then + # more stuff for OBS / SUSE / Fedora + cd home:Subsurface-Divelog/Subsurface-daily + osc rm $(ls subsurface*.tar.xz | grep -v $VERSION) + osc add subsurface-$VERSION.orig.tar.xz + sed -i "s/%define latestVersion.*/%define latestVersion $VERSION/" subsurfacedaily.spec + sed -i "s/%define gitVersion .*/%define gitVersion $GITREVISION/" subsurfacedaily.spec + osc commit -m "next daily build" + fi fi fi