aboutsummaryrefslogtreecommitdiff
path: root/devel/qt5/files/create_kde-qt_release.sh
diff options
context:
space:
mode:
Diffstat (limited to 'devel/qt5/files/create_kde-qt_release.sh')
-rw-r--r--devel/qt5/files/create_kde-qt_release.sh23
1 files changed, 14 insertions, 9 deletions
diff --git a/devel/qt5/files/create_kde-qt_release.sh b/devel/qt5/files/create_kde-qt_release.sh
index d46e4bd088d8..a255ea5e79f7 100644
--- a/devel/qt5/files/create_kde-qt_release.sh
+++ b/devel/qt5/files/create_kde-qt_release.sh
@@ -10,15 +10,13 @@ BASE_DIRECTORY="$2"
# Version of Qt we want
VERSION="$3"
ORIGIN_TAG="$4"
+BRANCH="$5"
# Remote KDE git repository
REPO="https://invent.kde.org/qt/qt/${PROJECT}.git"
# Local checkout
CHECKOUT="${BASE_DIRECTORY}/${PROJECT}"
-# KDE-Qt branch
-BRANCH=kde/5.15
-
# Make sure we can use ${BASE_DIRECTORY}
if [ ! -d "${BASE_DIRECTORY}" ] || [ ! -w "${BASE_DIRECTORY}" ] ; then
echo "Directory '${BASE_DIRECTORY}' does not exist"
@@ -27,11 +25,14 @@ fi
# Init a new git checkout if it is missing
if [ ! -d "${CHECKOUT}" ] ; then
- git -C "${BASE_DIRECTORY}" clone "${REPO}"
+ git -C "${BASE_DIRECTORY}" clone --recurse-submodules --no-remote-submodules "${REPO}"
fi
# Update the checkout of the required branch
-git -C "${CHECKOUT}" checkout "${BRANCH}" && git -C "${CHECKOUT}" pull --ff-only --rebase --autostash
+git -C "${CHECKOUT}" checkout "${BRANCH}" && \
+git -C "${CHECKOUT}" pull --ff-only --rebase --autostash && \
+git -C "${CHECKOUT}" submodule update
+
if [ $? -ne 0 ] ; then
echo "Failed to update ${CHECKOUT}"
exit 1
@@ -40,16 +41,20 @@ fi
# Count number of patches added by KDE
PATCH_COUNT=$(git -C ${CHECKOUT} rev-list --count ${ORIGIN_TAG}..origin/${BRANCH})
-# Setup information for the distfile
+# Set up information for the distfile
DISTNAME="kde-${PROJECT}-${VERSION}p${PATCH_COUNT}"
-DISTFILE="${BASE_DIRECTORY}/${DISTNAME}.tar.xz"
+DISTFILE_TAR="${BASE_DIRECTORY}/${DISTNAME}.tar"
+DISTFILE="${DISTFILE_TAR}.xz"
# Tar and compress distfile
-git -C ${CHECKOUT} archive --format=tar --prefix="${DISTNAME}/" HEAD | xz > "${DISTFILE}"
+git -C ${CHECKOUT} archive --format=tar --prefix="${DISTNAME}/" HEAD --output ${DISTFILE_TAR} && \
+git -C ${CHECKOUT} submodule foreach --recursive "git archive --prefix="${DISTNAME}"/\$path/ --output=${BASE_DIRECTORY}/\$sha1.tar HEAD && tar -r --file=${DISTFILE_TAR} @${BASE_DIRECTORY}/\$sha1.tar && rm ${BASE_DIRECTORY}/\$sha1.tar" && \
+xz ${DISTFILE_TAR}
+
if [ $? -ne 0 ] ; then
echo "Failed to create tarball ${DISTFILE}"
exit 1
fi
-# Printout information required in qt-dist.mk
+# Print out information required in qt-dist.mk
echo -e "Distfile:\t${DISTFILE}\n_KDE_${DIST}=\t${PATCH_COUNT}"