X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/988c59f51aa579ce8bf0eab1cc729e05a5ee5631..2be95ce7f069d9eb131b0d2d922a5e556f75810c:/sdk/cwl/arvados_version.py diff --git a/sdk/cwl/arvados_version.py b/sdk/cwl/arvados_version.py index 13e6d36c07..d9ce12487a 100644 --- a/sdk/cwl/arvados_version.py +++ b/sdk/cwl/arvados_version.py @@ -7,23 +7,34 @@ import time import os import re -def git_latest_tag(): - gitinfo = subprocess.check_output( - ['git', 'describe', '--abbrev=0']).strip() - return str(gitinfo.decode('utf-8')) +SETUP_DIR = os.path.dirname(os.path.abspath(__file__)) -def git_timestamp_tag(): - gitinfo = subprocess.check_output( +def choose_version_from(): + sdk_ts = subprocess.check_output( ['git', 'log', '--first-parent', '--max-count=1', - '--format=format:%ct', '.']).strip() - return str(time.strftime('.%Y%m%d%H%M%S', time.gmtime(int(gitinfo)))) + '--format=format:%ct', os.path.join(SETUP_DIR, "../python")]).strip() + cwl_ts = subprocess.check_output( + ['git', 'log', '--first-parent', '--max-count=1', + '--format=format:%ct', SETUP_DIR]).strip() + if int(sdk_ts) > int(cwl_ts): + getver = os.path.join(SETUP_DIR, "../python") + else: + getver = SETUP_DIR + return getver + +def git_version_at_commit(): + curdir = choose_version_from() + myhash = subprocess.check_output(['git', 'log', '-n1', '--first-parent', + '--format=%H', curdir]).strip() + myversion = subprocess.check_output([curdir+'/../../build/version-at-commit.sh', myhash]).strip().decode() + return myversion def save_version(setup_dir, module, v): - with open(os.path.join(setup_dir, module, "_version.py"), 'w') as fp: + with open(os.path.join(setup_dir, module, "_version.py"), 'wt') as fp: return fp.write("__version__ = '%s'\n" % v) def read_version(setup_dir, module): - with open(os.path.join(setup_dir, module, "_version.py"), 'r') as fp: + with open(os.path.join(setup_dir, module, "_version.py"), 'rt') as fp: return re.match("__version__ = '(.*)'$", fp.read()).groups()[0] def get_version(setup_dir, module): @@ -33,7 +44,7 @@ def get_version(setup_dir, module): save_version(setup_dir, module, env_version) else: try: - save_version(setup_dir, module, git_latest_tag() + git_timestamp_tag()) + save_version(setup_dir, module, git_version_at_commit()) except (subprocess.CalledProcessError, OSError): pass