2015-05-30 23:11:16 +01:00
|
|
|
"""
|
|
|
|
Generate header file with macros defining MicroPython version info.
|
|
|
|
|
|
|
|
This script works with Python 2.6, 2.7, 3.3 and 3.4.
|
|
|
|
"""
|
2015-04-22 17:38:05 +01:00
|
|
|
|
|
|
|
from __future__ import print_function
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
import datetime
|
|
|
|
import subprocess
|
|
|
|
|
2020-02-27 15:36:53 +11:00
|
|
|
|
2015-05-25 13:26:47 +01:00
|
|
|
def get_version_info_from_git():
|
2015-05-30 23:11:16 +01:00
|
|
|
# Python 2.6 doesn't have check_output, so check for that
|
|
|
|
try:
|
|
|
|
subprocess.check_output
|
|
|
|
subprocess.check_call
|
|
|
|
except AttributeError:
|
|
|
|
return None
|
|
|
|
|
2015-04-22 17:38:05 +01:00
|
|
|
# Note: git describe doesn't work if no tag is available
|
|
|
|
try:
|
2015-08-11 12:27:38 +01:00
|
|
|
git_tag = subprocess.check_output(
|
2021-07-05 10:37:34 -05:00
|
|
|
["git", "describe", "--tags", "--dirty", "--always", "--match", "v[1-9].*"],
|
2015-08-11 12:27:38 +01:00
|
|
|
stderr=subprocess.STDOUT,
|
|
|
|
universal_newlines=True,
|
|
|
|
).strip()
|
|
|
|
except subprocess.CalledProcessError as er:
|
2015-08-12 23:28:16 +01:00
|
|
|
if er.returncode == 128:
|
2015-08-11 12:27:38 +01:00
|
|
|
# git exit code of 128 means no repository found
|
|
|
|
return None
|
2015-04-22 17:38:05 +01:00
|
|
|
git_tag = ""
|
2015-05-25 13:26:47 +01:00
|
|
|
except OSError:
|
|
|
|
return None
|
2015-04-22 17:38:05 +01:00
|
|
|
try:
|
|
|
|
git_hash = subprocess.check_output(
|
|
|
|
["git", "rev-parse", "--short", "HEAD"],
|
|
|
|
stderr=subprocess.STDOUT,
|
|
|
|
universal_newlines=True,
|
|
|
|
).strip()
|
|
|
|
except subprocess.CalledProcessError:
|
|
|
|
git_hash = "unknown"
|
2015-05-25 13:26:47 +01:00
|
|
|
except OSError:
|
|
|
|
return None
|
2015-04-22 17:38:05 +01:00
|
|
|
|
|
|
|
try:
|
|
|
|
# Check if there are any modified files.
|
|
|
|
subprocess.check_call(
|
|
|
|
["git", "diff", "--no-ext-diff", "--quiet", "--exit-code"], stderr=subprocess.STDOUT
|
|
|
|
)
|
|
|
|
# Check if there are any staged files.
|
|
|
|
subprocess.check_call(
|
|
|
|
["git", "diff-index", "--cached", "--quiet", "HEAD", "--"], stderr=subprocess.STDOUT
|
|
|
|
)
|
|
|
|
except subprocess.CalledProcessError:
|
|
|
|
git_hash += "-dirty"
|
2015-05-25 13:26:47 +01:00
|
|
|
except OSError:
|
|
|
|
return None
|
2015-04-22 17:38:05 +01:00
|
|
|
|
2018-12-15 15:13:33 +11:00
|
|
|
return git_tag, git_hash
|
2015-05-25 13:26:47 +01:00
|
|
|
|
2020-02-27 15:36:53 +11:00
|
|
|
|
2015-05-25 13:26:47 +01:00
|
|
|
def get_version_info_from_docs_conf():
|
2015-10-29 19:16:48 -07:00
|
|
|
with open(os.path.join(os.path.dirname(sys.argv[0]), "..", "docs", "conf.py")) as f:
|
2015-05-25 13:26:47 +01:00
|
|
|
for line in f:
|
2017-07-04 22:37:41 +10:00
|
|
|
if line.startswith("version = release = '"):
|
|
|
|
ver = line.strip().split(" = ")[2].strip("'")
|
2015-05-25 13:26:47 +01:00
|
|
|
git_tag = "v" + ver
|
2018-12-15 15:13:33 +11:00
|
|
|
return git_tag, "<no hash>"
|
2015-05-25 13:26:47 +01:00
|
|
|
return None
|
|
|
|
|
2020-02-27 15:36:53 +11:00
|
|
|
|
2015-05-25 13:26:47 +01:00
|
|
|
def make_version_header(filename):
|
|
|
|
# Get version info using git, with fallback to docs/conf.py
|
|
|
|
info = get_version_info_from_git()
|
|
|
|
if info is None:
|
|
|
|
info = get_version_info_from_docs_conf()
|
|
|
|
|
2018-12-15 15:13:33 +11:00
|
|
|
git_tag, git_hash = info
|
2015-05-25 13:26:47 +01:00
|
|
|
|
2021-01-20 10:33:40 +01:00
|
|
|
build_date = datetime.date.today()
|
|
|
|
if "SOURCE_DATE_EPOCH" in os.environ:
|
|
|
|
build_date = datetime.datetime.utcfromtimestamp(
|
|
|
|
int(os.environ["SOURCE_DATE_EPOCH"])
|
|
|
|
).date()
|
|
|
|
|
2015-04-22 17:38:05 +01:00
|
|
|
# Generate the file with the git and version info
|
|
|
|
file_data = """\
|
|
|
|
// This file was generated by py/makeversionhdr.py
|
|
|
|
#define MICROPY_GIT_TAG "%s"
|
|
|
|
#define MICROPY_GIT_HASH "%s"
|
|
|
|
#define MICROPY_BUILD_DATE "%s"
|
2018-12-15 15:13:33 +11:00
|
|
|
""" % (
|
|
|
|
git_tag,
|
|
|
|
git_hash,
|
2021-01-20 10:33:40 +01:00
|
|
|
build_date.strftime("%Y-%m-%d"),
|
2018-12-15 15:13:33 +11:00
|
|
|
)
|
2015-04-22 17:38:05 +01:00
|
|
|
|
|
|
|
# Check if the file contents changed from last time
|
|
|
|
write_file = True
|
|
|
|
if os.path.isfile(filename):
|
|
|
|
with open(filename, "r") as f:
|
|
|
|
existing_data = f.read()
|
|
|
|
if existing_data == file_data:
|
|
|
|
write_file = False
|
|
|
|
|
|
|
|
# Only write the file if we need to
|
|
|
|
if write_file:
|
2018-02-22 11:35:53 +11:00
|
|
|
print("GEN %s" % filename)
|
2015-04-22 17:38:05 +01:00
|
|
|
with open(filename, "w") as f:
|
|
|
|
f.write(file_data)
|
|
|
|
|
2020-02-27 15:36:53 +11:00
|
|
|
|
2015-05-30 23:11:16 +01:00
|
|
|
if __name__ == "__main__":
|
|
|
|
make_version_header(sys.argv[1])
|