-
Notifications
You must be signed in to change notification settings - Fork 133
/
Copy pathutil.py
77 lines (57 loc) · 2 KB
/
util.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
import re
import requests
import subprocess
# 12.7.5-2, 12.7.5-3, ... -> 12.7.5
def strip_revision(tag) -> str:
return tag.split('-', 1)[0]
# gets last tag of GitHub project
def get_last_github_tag(project_name) -> str:
releases_url = f"https://api.github.com/repos/{project_name}/releases/latest"
releases = requests.get(releases_url).json()
# TODO: don't assume order
last_release = releases["tag_name"]
return last_release
# gets last tag of frida
def get_last_frida_tag() -> str:
last_frida_tag = get_last_github_tag('frida/frida')
print(f"Last frida tag: {last_frida_tag}")
return last_frida_tag
# gets last tag of whole project
def get_last_project_tag() -> str:
last_tag = get_last_tag([])
print(f"Last project tag: {last_tag}")
return last_tag
# gets last tag of current commit
def get_last_commit_tag() -> str:
last_tag = get_last_tag(["--points-at", "HEAD"])
print(f"Last commit tag: {last_tag}")
return last_tag
# properly sort tags (e.g. 1.11 > 1.9)
def sort_tags(tags: [str]) -> [str]:
tags = tags.copy()
s: str
tags.sort(key=lambda s: list(map(int, re.split(r"[\.-]", s))))
return tags
# gets last tag from filter
def get_last_tag(filter_args: [str]) -> str:
tags = exec_git_command(["tag", "-l"] + filter_args).splitlines()
last_tag = "" if len(tags) < 1 else sort_tags(tags)[-1]
return last_tag
# gets commit message
def get_commit_message() -> str:
message = exec_git_command(["log", "--format=%B", "-n", "1", "HEAD"])
return message.strip()
# executes a git command
def exec_git_command(command_with_args: [str]) -> str:
result = subprocess.run(["git"] + command_with_args,
capture_output=True).stdout
return result.decode()
# gets next tag in the form 12.7.5-1, 12.7.5-2...
def get_next_revision(current_tag: str) -> str:
i = 1
while True:
new_tag = f"{current_tag}-{i}"
if get_last_tag([new_tag]) == '':
break
i += 1
return new_tag