hard code version in app

This commit is contained in:
Dag Heyman 2018-11-05 09:11:21 +01:00
parent 2f4b911430
commit 285758a0ca
No known key found for this signature in database
GPG Key ID: 06FC004369E7D338
2 changed files with 8 additions and 138 deletions

View File

@ -1,112 +0,0 @@
#!/usr/bin/python3
# Compute version number from Git tags in current working directory
#
# - If the current commit has a tag starting with "yubioath-desktop-":
# - The rest of that tag is the version number.
# - If this version number has only two parts (X.Y), append ".0".
#
# - If the current commit does not have a tag:
# - Find the closest ancestor commit with a tag starting with
# "yubioath-desktop-", and use the rest of the tag as the version number.
# - If this version number has three parts ending with zero (X.Y.0), remove
# the ".0".
# - Append ".Z-gCOMMIT", where Z is the number of commits since the tagged
# ancestor commit and COMMIT is the short commit ID of the current commit
# - This will always be different from the latest tagged version number, and
# will always be a prerelease version because of the "-gCOMMIT" suffix
#
# - Finally, if the repository has uncommitted or untracked changes, append
# "-dirty".
# - For the VERSIONINFO in the Windows resource file, reformat the version
# number "X.Y.Z[-gCOMMIT][-dirty]" to 4 numeric parts:
# - Discard the "-gCOMMIT" and "-dirty" suffixes if present
# - If the "-dirty" suffix was present, append ".0".
# - If the "-dirty" suffix was not present, append ".1".
import argparse
import os
import re
import subprocess
import sys
def promote_commit_distance_to_patch_version(version):
'''If version starts with `X.Y-Z-g*`, and X, Y and Z are numeric, reformat
it to `X.Y.Z-g*`'''
return re.sub(
r'^([0-9]+\.[0-9]+)-([0-9]+)(-g.*)$', r'\1.\2\3',
version
)
def replace_zero_patch_version_with_commit_distance(version):
'''If version starts with `X.Y.0-Z-g*`, and X, Y and Z are numeric,
reformat it to `X.Y.Z-g*`'''
return re.sub(
r'^([0-9]+\.[0-9]+)\.0-([0-9]+)(-g.*)$', r'\1.\2\3',
version
)
def append_missing_patch_version(version):
'''If version is plain `X.Y`, append `.0`'''
return re.sub(
r'^([0-9]+\.[0-9]+)(-dirty)?$', r'\1.0\2',
version
)
def prepend_zero_version_to_raw_commit_id(version):
'''If version is raw abbreviated commit ID, prepend `0.0.0-`'''
return re.sub(
r'^([0-9a-f]{7}(-dirty)?)$', r'0.0.0-\1',
version
)
def compute_version(tag_prefix=None):
git_result = subprocess.run(
['git', 'describe',
'--tags',
'--dirty=-dirty',
'--always',
] + (
['--match=%s*' % tag_prefix] if tag_prefix else []
),
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
universal_newlines=True
)
if git_result.returncode is not 0:
raise ChildProcessError(git_result.stderr) # noqa: F821
git_version = git_result.stdout.strip()
if tag_prefix:
# Remove tag prefix
git_version = re.sub(r'^' + tag_prefix, '', git_version)
git_version = prepend_zero_version_to_raw_commit_id(git_version)
return git_version
if __name__ == '__main__':
parser = argparse.ArgumentParser(
description='Compute version number from Git tags',
add_help=True
)
parser.add_argument('-f', '--version-file',
action='store', dest='version_file',
help='Read version from VERSION_FILE if it exists')
parser.add_argument('tag_prefix',
action='store',
help='Prefix for git tags eligible as version tags')
args = parser.parse_args()
if args.version_file is not None and os.path.isfile(args.version_file):
with open(args.version_file) as f:
sys.stdout.write(f.read())
else:
print(compute_version(tag_prefix=args.tag_prefix))

View File

@ -1,36 +1,20 @@
TEMPLATE = app
QT += qml quick widgets
CONFIG += c++11
unix {
QMAKE_CXXFLAGS += -pedantic-errors
}
SOURCES += main.cpp \
systemtray.cpp
SOURCES += main.cpp systemtray.cpp
HEADERS += screenshot.h systemtray.h
# This is the verson number for the application,
# will be in info.plist file, about page etc.
PYTHON3_BINARY_NAME=python3
# This is the internal verson number, Windows requires 4 digits.
win32|win64 {
PYTHON3_BINARY_NAME=python
VERSION = 4.3.5.0
} else {
VERSION = 4.3.5
}
VERSION = $$system($$PYTHON3_BINARY_NAME compute-version.py -f VERSION yubioath-desktop-)
# This is the version shown on the About page
DEFINES += APP_VERSION=\\\"4.3.5\\\"
message(Version of this build: $$VERSION)
DEFINES += APP_VERSION=\\\"$$VERSION\\\"
win32|win64 {
# Strip suffixes from version number
# Because rc compiler requires only numerals in the version number
# If version contains "-", output version (0, 0, 0, 0)
# Otherwise assume version is "X.Y.Z", where X, Y, Z are all numeric. Output version (X, Y, Z, 0).
VERSION ~= s/^.*-.*$/0.0.0.0
VERSION ~= s/^([0-9]+\.[0-9]+\.[0-9]+)$/\1.0
message(Version tweaked for Windows build: $$VERSION)
}
buildqrc.commands = python build_qrc.py ${QMAKE_FILE_IN}
buildqrc.input = QRC_JSON
buildqrc.output = ${QMAKE_FILE_IN_BASE}.qrc
@ -78,8 +62,6 @@ lupdate_only {
qml/slot/*.qml
}
HEADERS += screenshot.h \
systemtray.h
DISTFILES += \
py/* \