aboutsummaryrefslogtreecommitdiff
path: root/roll-tarballs.sh
diff options
context:
space:
mode:
authorMike Gabriel <mike.gabriel@das-netzwerkteam.de>2016-06-23 21:33:23 +0200
committerMike Gabriel <mike.gabriel@das-netzwerkteam.de>2016-07-01 13:55:27 +0200
commit2d016f826adbb816de012ac0c57e7efd226dbb3f (patch)
tree4a8133ac77fe61c051b90d9b6dc66dd6d8f5cf46 /roll-tarballs.sh
parent82a8d595ddfd324991793a19936cc8f1539a9ed7 (diff)
downloadnx-libs-2d016f826adbb816de012ac0c57e7efd226dbb3f.tar.gz
nx-libs-2d016f826adbb816de012ac0c57e7efd226dbb3f.tar.bz2
nx-libs-2d016f826adbb816de012ac0c57e7efd226dbb3f.zip
roll-tarball.sh: Move out of debian/ folder into project's base folder.
Diffstat (limited to 'roll-tarballs.sh')
-rwxr-xr-xroll-tarballs.sh157
1 files changed, 157 insertions, 0 deletions
diff --git a/roll-tarballs.sh b/roll-tarballs.sh
new file mode 100755
index 000000000..60b5e916f
--- /dev/null
+++ b/roll-tarballs.sh
@@ -0,0 +1,157 @@
+#!/bin/bash
+
+# Copyright (C) 2011-2016 by Mike Gabriel <mike.gabriel@das-netzwerkteam.de>
+# Copyright (C) 2012 by Reinhard Tartler <siretart@tauware.de>
+#
+# This is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+
+# Thanks to Jonas Smedegaard <dr@jones.dk> for inspiration...
+
+# Formatting/cleanups by siretart in December 2012
+
+set -e
+
+usage() {
+ echo "To be called at the project root of an nx-libs checkout"
+ echo "usage: $(basename "$0") {<release-version>,HEAD} {server|client}"
+ exit 1
+}
+
+PROJECT="nx-libs"
+NULL=""
+
+test -d ".git" || usage
+RELEASE="$1"
+test -n "${RELEASE}" || usage
+CHECKOUT="$2"
+test -n "$CHECKOUT" || usage
+
+if [ "x$CHECKOUT" = "xserver" ] || [ "x${CHECKOUT}" = "xfull" ]; then
+ MODE="full"
+ CHECKOUT="redist-server/${RELEASE}"
+ RELEASE_SUFFIX='-full'
+elif [ "x$CHECKOUT" = "xclient" ] || [ "x${CHECKOUT}" = "xlite" ]; then
+ MODE="lite"
+ CHECKOUT="redist-client/${RELEASE}"
+ RELEASE_SUFFIX='-lite'
+else
+ usage
+fi
+
+if [ x"$RELEASE" == "xHEAD" ]; then
+ CHECKOUT="refs/heads/$(git rev-parse --abbrev-ref HEAD)"
+fi
+
+if ! git rev-parse --verify -q "$CHECKOUT" >/dev/null; then
+ echo " '${RELEASE}' is not a valid release number because there is no git tag named ${CHECKOUT}."
+ echo " Please specify one of the following releases:"
+ echo "HEAD (on branch `git rev-parse --abbrev-ref HEAD`)"
+ git tag -l | grep "^redist" | cut -f2 -d"/" | sort -u
+ exit 1
+fi
+
+TARGETDIR=".."
+
+MANIFEST="$(mktemp)"
+TEMP_DIR="$(mktemp -d)"
+
+trap "rm -f \"${MANIFEST}\"; rm -rf \"${TEMP_DIR}\"" 0
+
+# create local copy of Git project at temp location
+git archive --format=tar "${CHECKOUT}" --prefix="${PROJECT}-${RELEASE}/" | ( cd "$TEMP_DIR"; tar xf - )
+git --no-pager log --after "1972-01-01" --format="%ai %aN (%h) %n%n%x09*%w(68,0,10) %s%d%n" > "${TEMP_DIR}/${PROJECT}-${RELEASE}/ChangeLog"
+
+echo "Created tarball for $CHECKOUT"
+
+cd "${TEMP_DIR}/${PROJECT}-${RELEASE}/"
+
+# Replace symlinks by copies of the linked target files
+# Note: We don't have symlinked directories!!!
+find . -type "l" | while read link; do
+ TARGET="$(readlink "${link}")"
+ pushd "$(dirname "${link}")" >/dev/null
+ if [ -f "${TARGET}" ]; then
+ rm -f "$(basename "${link}")"
+ cp "${TARGET}" "$(basename "${link}")"
+ fi
+ popd >/dev/null
+done
+
+mkdir -p "doc/applied-patches"
+
+# prepare patches for lite and full tarball
+if [ "x$MODE" = "xfull" ]; then
+ cat "debian/patches/series" | sort | grep -v '^#' | egrep "([0-9]+(_|-).*\.(full|full\+lite)\.patch)" | while read file
+ do
+ cp -v "debian/patches/$file" "doc/applied-patches/"
+ echo "${file##*/}" >> "doc/applied-patches/series"
+ done
+else
+ rm -f "bin/"{nxagent,nxauth}
+ rm -Rf "nxcompshad"*
+ rm -Rf "nxcompext"*
+ rm -Rf "nx-X11"*
+ rm -Rf "etc"*
+ rm -Rf "doc/nx-X11_vs_XOrg69_patches"*
+ rm -Rf "doc/X11-symbols"*
+ rm -f "README.keystrokes"
+ cat "debian/patches/series" | sort | grep -v '^#' | egrep "([0-9]+(_|-).*\.full\+lite\.patch)" | while read file
+ do
+ cp -v "debian/patches/$file" "doc/applied-patches/"
+ echo "${file##*/}" >> "doc/applied-patches/series"
+ done
+fi
+
+# apply all patches shipped in debian/patches and create a copy of them that we ship with the tarball
+if [ -s "doc/applied-patches/series" ]; then
+ QUILT_PATCHES="doc/applied-patches" quilt --quiltrc /dev/null push -a -q
+else
+ echo "No patches applied at all. Very old release?"
+fi
+
+# remove folders that we do not want to roll into the tarball
+rm -Rf ".pc/"
+rm -Rf "debian/"
+rm -Rf "nx-libs.spec"
+
+# very old release did not add any README
+for f in $(ls README* 2>/dev/null); do
+ mv -v "$f" "doc/";
+done
+
+# remove files, that we do not want in the tarballs (build cruft)
+rm -Rf nx*/configure nx*/autom4te.cache*
+
+cd "$OLDPWD"
+
+# create target location for tarball
+mkdir -p "${TARGETDIR}/_releases_/source/${PROJECT}/"
+
+# roll the ball...
+cd "$TEMP_DIR"
+find "${PROJECT}-${RELEASE}" -type f | sort > "$MANIFEST"
+cd "$OLDPWD"
+
+tar c -C "$TEMP_DIR" \
+ --owner 0 \
+ --group 0 \
+ --numeric-owner \
+ --no-recursion \
+ --files-from "$MANIFEST" \
+ --gzip \
+ > "$TARGETDIR/_releases_/source/${PROJECT}/${PROJECT}-${RELEASE}${RELEASE_SUFFIX}.tar.gz"
+
+echo "$TARGETDIR/_releases_/source/${PROJECT}/${PROJECT}-${RELEASE}${RELEASE_SUFFIX}.tar.gz is ready"