123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- import subprocess
- import os
- import re
- from email.utils import formatdate
- import datetime
- dirpath = os.path.join(os.path.dirname(os.path.realpath(__file__)),"..")
- git_describe_version = subprocess.check_output(["git", "describe", "--tags", "--dirty", "--match", "v*"]).decode('utf-8').strip()
- m = re.match(r"^v([0-9]+)(\.[0-9]+)?(\.[0-9]+)?(-(.*)+)?$", git_describe_version)
- version_major = m.group(1) if m.group(1) is not None else "0"
- version_minor = m.group(2).replace(".", "") if m.group(2) is not None else "0"
- version_patch = m.group(3).replace(".", "") if m.group(3) is not None else "0"
- version_label = m.group(4) if m.group(4) is not None else ""
- debian_distribution = "UNRELEASED"
- debian_path = os.path.join(dirpath, "debian")
- changelog_file = os.path.join(debian_path, "changelog")
- changelog_version = git_describe_version[1:] if git_describe_version[0] == 'v' else git_describe_version
- changelog_version = changelog_version.replace('-', '~')
- changelog_version = datetime.datetime.utcnow().replace(microsecond=0).isoformat().replace('-', '').replace(':', '') + '~' + changelog_version
- with open(changelog_file, 'r') as original: data = original.read()
- with open(changelog_file, 'w') as modified:
- new_entry = """open62541 ({version}) {distribution}; urgency=medium
- * Full changelog is available here:
- https://github.com/open62541/open62541/blob/master/CHANGELOG
- -- open62541 Team <open62541-core@googlegroups.com> {time}
- """.format(version=changelog_version, time=formatdate(), distribution = debian_distribution)
- modified.write(new_entry + "\n" + data)
- control_file_template = os.path.join(debian_path, "control-template")
- control_file = os.path.join(debian_path, "control")
- os.rename(control_file_template, control_file)
- with open(control_file, 'r+') as f:
- content = f.read()
- f.seek(0)
- f.truncate()
- f.write(content.replace('<soname>', "{}".format(version_major)))
- install_file_template = os.path.join(debian_path, "libopen62541.install-template")
- install_file = os.path.join(debian_path, "libopen62541-{}.install".format(version_major))
- os.rename(install_file_template, install_file)
- install_file_template = os.path.join(debian_path, "libopen62541-dev.install-template")
- install_file = os.path.join(debian_path, "libopen62541-{}-dev.install".format(version_major))
- os.rename(install_file_template, install_file)
- install_file_template = os.path.join(debian_path, "libopen62541-tools.install-template")
- install_file = os.path.join(debian_path, "libopen62541-{}-tools.install".format(version_major))
- os.rename(install_file_template, install_file)
- install_file_template = os.path.join(debian_path, "open62541-doc.doc-base-template")
- install_file = os.path.join(debian_path, "open62541-doc.doc-base")
- os.rename(install_file_template, install_file)
- install_file_template = os.path.join(debian_path, "open62541-doc.install-template")
- install_file = os.path.join(debian_path, "open62541-doc.install")
- os.rename(install_file_template, install_file)
- rule_file_template = os.path.join(debian_path, "rules-template")
- rule_file = os.path.join(debian_path, "rules")
- os.rename(rule_file_template, rule_file)
- with open(rule_file, 'r+') as f:
- content = f.read()
- f.seek(0)
- f.truncate()
- content = content.replace('<soname>', "{}".format(version_major))
- f.write(content)
- with open(os.path.join(dirpath,"CMakeLists.txt"), 'r+') as f:
- lines = f.readlines()
- f.seek(0)
- f.truncate()
- for idx, line in enumerate(lines):
- if idx == 2:
- f.write('set(OPEN62541_VERSION "{}")\n'.format(git_describe_version))
- f.write(line)
|