forked from ClangBuiltLinux/tc-build
-
Notifications
You must be signed in to change notification settings - Fork 3
/
utils.py
executable file
·100 lines (83 loc) · 2.81 KB
/
utils.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#!/usr/bin/env python3
# Description: Common helper functions
import re
import subprocess
import sys
import time
def create_gitignore(folder):
"""
Create a gitignore that ignores all files in a folder. Some folders are not
known until the script is run so they can't be added to the root .gitignore
:param folder: Folder to create the gitignore in
"""
folder.joinpath('gitignore').write_text('*\n', encoding='utf-8')
def flush_std_err_out():
sys.stderr.flush()
sys.stdout.flush()
def libc_is_musl():
"""
Returns whether or not the current libc is musl or not.
"""
# musl's ldd does not appear to support '--version' directly, as its return
# code is 1 and it prints all text to stderr. However, it does print the
# version information so it is good enough. Just 'check=False' it and move
# on.
ldd_out = subprocess.run(['ldd', '--version'],
capture_output=True,
check=False,
text=True)
if re.search('musl', ldd_out.stderr if ldd_out.stderr else ldd_out.stdout):
return True
return False
def get_duration(start_seconds, end_seconds=None):
"""
Formats a duration in days, hours, minutes, and seconds.
:param start_seconds: The start of the duration
:param end_seconds: The end of the duration; can be omitted for current time
:return: A string with the non-zero parts of the duration.
"""
if not end_seconds:
end_seconds = time.time()
seconds = int(end_seconds - start_seconds)
days, seconds = divmod(seconds, 60 * 60 * 24)
hours, seconds = divmod(seconds, 60 * 60)
minutes, seconds = divmod(seconds, 60)
parts = []
if days:
parts.append(f"{days}d")
if hours:
parts.append(f"{hours}h")
if minutes:
parts.append(f"{minutes}m")
parts.append(f"{seconds}s")
return ' '.join(parts)
def print_header(string):
"""
Prints a fancy header
:param string: String to print inside the header
"""
# Use bold cyan for the header so that the headers
# are not intepreted as success (green) or failed (red)
print("\033[01;36m")
for _ in range(0, len(string) + 6):
print("=", end="")
print(f"\n== {string} ==")
for _ in range(0, len(string) + 6):
print("=", end="")
# \033[0m resets the color back to the user's default
print("\n\033[0m")
flush_std_err_out()
def print_error(string):
"""
Prints a error in bold red
:param string: String to print
"""
# Use bold red for error
print(f"\033[01;31m{string}\n\033[0m", flush=True)
def print_warning(string):
"""
Prints a error in bold yellow
:param string: String to print
"""
# Use bold yellow for error
print(f"\033[01;33m{string}\n\033[0m", flush=True)