mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-04 21:17:43 +03:00
Update release tool and snapcraft.yaml (#610)
* Release tool checks snapcraft file for version and added removable-media plug * Added 'check' command to release tool. Code cleanup.
This commit is contained in:
parent
1847312c7a
commit
458c76d3b7
2 changed files with 106 additions and 73 deletions
177
release-tool
177
release-tool
|
@ -50,19 +50,20 @@ printUsage() {
|
||||||
local cmd
|
local cmd
|
||||||
if [ "" == "$1" ] || [ "help" == "$1" ]; then
|
if [ "" == "$1" ] || [ "help" == "$1" ]; then
|
||||||
cmd="COMMAND"
|
cmd="COMMAND"
|
||||||
elif [ "merge" == "$1" ] || [ "build" == "$1" ] || [ "sign" == "$1" ]; then
|
elif [ "check" == "$1" ] || [ "merge" == "$1" ] || [ "build" == "$1" ] || [ "sign" == "$1" ]; then
|
||||||
cmd="$1"
|
cmd="$1"
|
||||||
else
|
else
|
||||||
logError "Unknown command: '$1'\n"
|
logError "Unknown command: '$1'\n"
|
||||||
cmd="COMMAND"
|
cmd="COMMAND"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
printf "\e[1mUsage:\e[0m $(basename $0) $cmd [options]\n"
|
printf "\e[1mUsage:\e[0m $(basename $0) $cmd [--version x.y.z] [options]\n"
|
||||||
|
|
||||||
if [ "COMMAND" == "$cmd" ]; then
|
if [ "COMMAND" == "$cmd" ]; then
|
||||||
cat << EOF
|
cat << EOF
|
||||||
|
|
||||||
Commands:
|
Commands:
|
||||||
|
check Perform a dry-run check, nothing is changed
|
||||||
merge Merge release branch into main branch and create release tags
|
merge Merge release branch into main branch and create release tags
|
||||||
build Build and package binary release from sources
|
build Build and package binary release from sources
|
||||||
sign Sign previously compiled release packages
|
sign Sign previously compiled release packages
|
||||||
|
@ -134,7 +135,22 @@ logError() {
|
||||||
}
|
}
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
|
if [ "" == "$RELEASE_NAME" ]; then
|
||||||
|
logError "Missing arguments, --version is required!\n"
|
||||||
|
printUsage "check"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "" == "$TAG_NAME" ]; then
|
||||||
|
TAG_NAME="$RELEASE_NAME"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "" == "$SOURCE_BRANCH" ]; then
|
||||||
|
SOURCE_BRANCH="release/${RELEASE_NAME}"
|
||||||
|
fi
|
||||||
|
|
||||||
ORIG_CWD="$(pwd)"
|
ORIG_CWD="$(pwd)"
|
||||||
|
SRC_DIR="$(realpath "$SRC_DIR")"
|
||||||
cd "$SRC_DIR" > /dev/null 2>&1
|
cd "$SRC_DIR" > /dev/null 2>&1
|
||||||
ORIG_BRANCH="$(git rev-parse --abbrev-ref HEAD 2> /dev/null)"
|
ORIG_BRANCH="$(git rev-parse --abbrev-ref HEAD 2> /dev/null)"
|
||||||
cd "$ORIG_CWD"
|
cd "$ORIG_CWD"
|
||||||
|
@ -214,15 +230,23 @@ checkTargetBranchExists() {
|
||||||
|
|
||||||
checkVersionInCMake() {
|
checkVersionInCMake() {
|
||||||
local app_name_upper="$(echo "$APP_NAME" | tr '[:lower:]' '[:upper:]')"
|
local app_name_upper="$(echo "$APP_NAME" | tr '[:lower:]' '[:upper:]')"
|
||||||
|
local major_num="$(echo ${RELEASE_NAME} | cut -f1 -d.)"
|
||||||
grep -q "${app_name_upper}_VERSION \"${RELEASE_NAME}\"" CMakeLists.txt
|
local minor_num="$(echo ${RELEASE_NAME} | cut -f2 -d.)"
|
||||||
|
local patch_num="$(echo ${RELEASE_NAME} | cut -f3 -d.)"
|
||||||
|
|
||||||
|
grep -q "${app_name_upper}_VERSION_MAJOR \"${major_num}\"" CMakeLists.txt
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
exitError "${app_name_upper}_VERSION version not updated to '${RELEASE_NAME}' in CMakeLists.txt!"
|
exitError "${app_name_upper}_VERSION_MAJOR not updated to '${major_num}' in CMakeLists.txt!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
grep -q "${app_name_upper}_VERSION_NUM \"${RELEASE_NAME}\"" CMakeLists.txt
|
grep -q "${app_name_upper}_VERSION_MINOR \"${minor_num}\"" CMakeLists.txt
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
exitError "${app_name_upper}_VERSION_NUM version not updated to '${RELEASE_NAME}' in CMakeLists.txt!"
|
exitError "${app_name_upper}_VERSION_MINOR not updated to '${minor_num}' in CMakeLists.txt!"
|
||||||
|
fi
|
||||||
|
|
||||||
|
grep -q "${app_name_upper}_VERSION_PATCH \"${patch_num}\"" CMakeLists.txt
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
exitError "${app_name_upper}_VERSION_PATCH not updated to '${patch_num}' in CMakeLists.txt!"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -242,6 +266,52 @@ checkTransifexCommandExists() {
|
||||||
if [ 0 -ne $? ]; then
|
if [ 0 -ne $? ]; then
|
||||||
exitError "Transifex tool 'tx' not installed! Please install it using 'pip install transifex-client'"
|
exitError "Transifex tool 'tx' not installed! Please install it using 'pip install transifex-client'"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
command -v lupdate-qt5 > /dev/null
|
||||||
|
if [ 0 -ne $? ]; then
|
||||||
|
exitError "Qt Linguist tool (lupdate-qt5) is not installed! Please install using 'apt install qttools5-dev-tools'"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
checkSnapcraft() {
|
||||||
|
if [ ! -f snapcraft.yaml ]; then
|
||||||
|
echo "No snapcraft file found!"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
grep -qPzo "version: ${RELEASE_NAME}" snapcraft.yaml
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
exitError "snapcraft.yaml has not been updated to the '${RELEASE_NAME}' release!"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
performChecks() {
|
||||||
|
logInfo "Performing basic checks..."
|
||||||
|
|
||||||
|
checkSourceDirExists
|
||||||
|
|
||||||
|
logInfo "Changing to source directory..."
|
||||||
|
cd "${SRC_DIR}"
|
||||||
|
|
||||||
|
logInfo "Validating toolset and repository..."
|
||||||
|
|
||||||
|
checkTransifexCommandExists
|
||||||
|
checkGitRepository
|
||||||
|
checkReleaseDoesNotExist
|
||||||
|
checkWorkingTreeClean
|
||||||
|
checkSourceBranchExists
|
||||||
|
checkTargetBranchExists
|
||||||
|
|
||||||
|
logInfo "Checking out '${SOURCE_BRANCH}'..."
|
||||||
|
git checkout "$SOURCE_BRANCH"
|
||||||
|
|
||||||
|
logInfo "Attempting to find '${RELEASE_NAME}' in various files..."
|
||||||
|
|
||||||
|
checkVersionInCMake
|
||||||
|
checkChangeLog
|
||||||
|
checkSnapcraft
|
||||||
|
|
||||||
|
logInfo "\e[1m\e[32mAll checks passed!\e[0m"
|
||||||
}
|
}
|
||||||
|
|
||||||
# re-implement realpath for OS X (thanks mschrag)
|
# re-implement realpath for OS X (thanks mschrag)
|
||||||
|
@ -269,6 +339,28 @@ fi
|
||||||
|
|
||||||
trap exitTrap SIGINT SIGTERM
|
trap exitTrap SIGINT SIGTERM
|
||||||
|
|
||||||
|
# -----------------------------------------------------------------------
|
||||||
|
# check command
|
||||||
|
# -----------------------------------------------------------------------
|
||||||
|
check() {
|
||||||
|
while [ $# -ge 1 ]; do
|
||||||
|
local arg="$1"
|
||||||
|
case "$arg" in
|
||||||
|
-v|--version)
|
||||||
|
RELEASE_NAME="$2"
|
||||||
|
shift ;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
init
|
||||||
|
|
||||||
|
performChecks
|
||||||
|
|
||||||
|
cleanup
|
||||||
|
|
||||||
|
logInfo "Congrats! You can successfully merge, build, and sign KeepassXC."
|
||||||
|
}
|
||||||
|
|
||||||
# -----------------------------------------------------------------------
|
# -----------------------------------------------------------------------
|
||||||
# merge command
|
# merge command
|
||||||
|
@ -317,45 +409,9 @@ merge() {
|
||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "" == "$RELEASE_NAME" ]; then
|
|
||||||
logError "Missing arguments, --version is required!\n"
|
|
||||||
printUsage "merge"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "" == "$TAG_NAME" ]; then
|
|
||||||
TAG_NAME="$RELEASE_NAME"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "" == "$SOURCE_BRANCH" ]; then
|
|
||||||
SOURCE_BRANCH="release/${RELEASE_NAME}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
init
|
init
|
||||||
|
|
||||||
SRC_DIR="$(realpath "$SRC_DIR")"
|
performChecks
|
||||||
|
|
||||||
logInfo "Performing basic checks..."
|
|
||||||
|
|
||||||
checkSourceDirExists
|
|
||||||
|
|
||||||
logInfo "Changing to source directory..."
|
|
||||||
cd "${SRC_DIR}"
|
|
||||||
|
|
||||||
checkTransifexCommandExists
|
|
||||||
checkGitRepository
|
|
||||||
checkReleaseDoesNotExist
|
|
||||||
checkWorkingTreeClean
|
|
||||||
checkSourceBranchExists
|
|
||||||
checkTargetBranchExists
|
|
||||||
|
|
||||||
logInfo "Checking out source branch '${SOURCE_BRANCH}'..."
|
|
||||||
git checkout "$SOURCE_BRANCH"
|
|
||||||
|
|
||||||
checkVersionInCMake
|
|
||||||
checkChangeLog
|
|
||||||
|
|
||||||
logInfo "All checks pass, getting our hands dirty now!"
|
|
||||||
|
|
||||||
logInfo "Updating language files..."
|
logInfo "Updating language files..."
|
||||||
./share/translations/update.sh
|
./share/translations/update.sh
|
||||||
|
@ -467,36 +523,13 @@ build() {
|
||||||
esac
|
esac
|
||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "" == "$RELEASE_NAME" ]; then
|
|
||||||
logError "Missing arguments, --version is required!\n"
|
|
||||||
printUsage "build"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "" == "$TAG_NAME" ]; then
|
|
||||||
TAG_NAME="$RELEASE_NAME"
|
|
||||||
fi
|
|
||||||
|
|
||||||
init
|
|
||||||
|
|
||||||
SRC_DIR="$(realpath "$SRC_DIR")"
|
init
|
||||||
|
|
||||||
|
performChecks
|
||||||
|
|
||||||
OUTPUT_DIR="$(realpath "$OUTPUT_DIR")"
|
OUTPUT_DIR="$(realpath "$OUTPUT_DIR")"
|
||||||
|
|
||||||
logInfo "Performing basic checks..."
|
|
||||||
|
|
||||||
checkSourceDirExists
|
|
||||||
|
|
||||||
logInfo "Changing to source directory..."
|
|
||||||
cd "${SRC_DIR}"
|
|
||||||
|
|
||||||
checkTagExists
|
|
||||||
checkGitRepository
|
|
||||||
checkWorkingTreeClean
|
|
||||||
checkOutputDirDoesNotExist
|
|
||||||
|
|
||||||
logInfo "All checks pass, getting our hands dirty now!"
|
|
||||||
|
|
||||||
logInfo "Checking out release tag '${TAG_NAME}'..."
|
logInfo "Checking out release tag '${TAG_NAME}'..."
|
||||||
git checkout "$TAG_NAME"
|
git checkout "$TAG_NAME"
|
||||||
|
|
||||||
|
@ -678,7 +711,7 @@ if [ "" == "$MODE" ]; then
|
||||||
elif [ "help" == "$MODE" ]; then
|
elif [ "help" == "$MODE" ]; then
|
||||||
printUsage "$1"
|
printUsage "$1"
|
||||||
exit
|
exit
|
||||||
elif [ "merge" == "$MODE" ] || [ "build" == "$MODE" ] || [ "sign" == "$MODE" ]; then
|
elif [ "check" == "$MODE" ] || [ "merge" == "$MODE" ] || [ "build" == "$MODE" ] || [ "sign" == "$MODE" ]; then
|
||||||
$MODE "$@"
|
$MODE "$@"
|
||||||
else
|
else
|
||||||
printUsage "$MODE"
|
printUsage "$MODE"
|
||||||
|
|
|
@ -11,7 +11,7 @@ confinement: strict
|
||||||
apps:
|
apps:
|
||||||
keepassxc:
|
keepassxc:
|
||||||
command: desktop-launch keepassxc
|
command: desktop-launch keepassxc
|
||||||
plugs: [unity7, x11, opengl, gsettings, home, network, network-bind]
|
plugs: [unity7, x11, opengl, gsettings, home, network, network-bind, removable-media]
|
||||||
|
|
||||||
parts:
|
parts:
|
||||||
keepassxc:
|
keepassxc:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue