-
-
Notifications
You must be signed in to change notification settings - Fork 399
/
git-version.py
82 lines (74 loc) · 2.53 KB
/
git-version.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import subprocess
import filecmp, tempfile, shutil, os
# Thank you https://docs.platformio.org/en/latest/projectconf/section_env_build.html !
gitFail = False
try:
subprocess.check_call(["git", "status"], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
except:
gitFail = True
if gitFail:
tag = "v3.0.x"
rev = " (noGit)"
url = " (noGit)"
else:
try:
tag = (
subprocess.check_output(["git", "describe", "--tags", "--abbrev=0"], stderr=subprocess.DEVNULL)
.strip()
.decode("utf-8")
)
except:
tag = "v3.0.x"
# Check to see if the head commit exactly matches a tag.
# If so, the revision is "release", otherwise it is BRANCH-COMMIT
try:
subprocess.check_call(["git", "describe", "--tags", "--exact"], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
rev = ''
except:
branchname = (
subprocess.check_output(["git", "rev-parse", "--abbrev-ref", "HEAD"])
.strip()
.decode("utf-8")
)
revision = (
subprocess.check_output(["git", "rev-parse", "--short", "HEAD"])
.strip()
.decode("utf-8")
)
modified = (
subprocess.check_output(["git", "status", "-uno", "-s"])
.strip()
.decode("utf-8")
)
if modified:
dirty = "-dirty"
else:
dirty = ""
rev = " (%s-%s%s)" % (branchname, revision, dirty)
url = (
subprocess.check_output(["git", "config", "--get", "remote.origin.url"])
.strip()
.decode("utf-8")
)
grbl_version = tag.replace('v','').rpartition('.')[0]
git_info = '%s%s' % (tag, rev)
git_url = url
provisional = "FluidNC/src/version.cxx"
final = "FluidNC/src/version.cpp"
with open(provisional, "w") as fp:
fp.write('const char* grbl_version = \"' + grbl_version + '\";\n')
fp.write('const char* git_info = \"' + git_info + '\";\n')
fp.write('const char* git_url = \"' + git_url + '\";\n')
if not os.path.exists(final):
# No version.cpp so rename version.cxx to version.cpp
os.rename(provisional, final)
elif not filecmp.cmp(provisional, final):
# version.cxx differs from version.cpp so get rid of the
# old .cpp and rename .cxx to .cpp
os.remove(final)
os.rename(provisional, final)
else:
# The existing version.cpp is the same as the new version.cxx
# so we can just leave the old version.cpp in place and get
# rid of version.cxx
os.remove(provisional)