-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbuild.py
executable file
·173 lines (129 loc) · 5.63 KB
/
build.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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
#!/usr/bin/env python3
"""
VDGE Build is a cross-platform script used to build the application
It automatically runs the post-build script when build succeded
Can be used to only update libraries, by using just the update param
Commands available: help, build, update
"""
import os
import sys
import json
import subprocess
import shutil
from meta.resource_manager import resource_update
from meta.update_manager import update
CONFIG_PATH = os.path.join('meta', 'config.json')
def conclusion(module, rc):
if rc == 0:
print ('\n=====================================')
print ('{} SUCCESSFUL'.format(module))
print ('=====================================\n')
else:
print ('\n=====================================')
print ('{} FAILED'.format(module))
print ('=====================================\n')
exit (1)
def extract_params(argv):
params = {}
for arg in argv:
if not (arg.startswith('-') or arg.startswith('--')):
print ('[#] Ignoring unrecognized argument "{}"'.format(name))
continue
is_long = True if arg.startswith('--') else False
t = arg.split('=')
name = t[0][2:] if is_long else t[0][1:]
value = None if len(t) < 2 else t[1]
params[name] = value
return params
def configure(build_type, output_dir, verbose = True, clean_configure = False):
print ('[>] Building in {} mode. Binary will be created at {}.'.format(build_type, output_dir))
if clean_configure and os.path.isdir(output_dir):
shutil.rmtree(output_dir)
cmd = 'cmake -DCMAKE_BUILD_TYPE={} -B{}'.format(build_type, output_dir)
p = None
if verbose:
p = subprocess.run(cmd, shell=True)
else:
p = subprocess.run(cmd, shell=True, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
return p.returncode
def run(command_name, value, default, config):
if command_name == 'build':
if value == None:
value = default
directory = config['BUILD_RELEASE_OUTPUT_DIR'] if value.startswith('r') else config['BUILD_DEBUG_OUTPUT_DIR']
value = 'Release' if value.startswith('r') else 'Debug'
if configure(value, directory) == 0:
cwd = os.getcwd()
os.chdir(directory)
p = subprocess.run('make')
os.chdir(cwd)
conclusion("BUILD", p.returncode)
else:
conclusion("BUILD", 1)
elif command_name == 'update':
rc = update(config['PACKAGE_FILE'], config['UPDATE_CACHE_DIR'], config['INCLUDE_DIR'], config['LIB_DIR'])
conclusion("UPDATE", rc)
elif command_name == 'help':
print ('[!] VDGE Build System Help Menu')
for cmd in config['COMMANDS']:
print ('[=] --{}, -{} <=> {}'.format(cmd['NAME'], cmd['SHORT'], cmd['DESCRIPTION']))
if len(cmd['VALUES']) > 0:
print ('\t[?] Possible values: {}'.format(cmd['VALUES']))
elif command_name == 'resource-update':
rc = 1
if value == None:
rc1 = resource_update(os.getcwd(), config['BUILD_RELEASE_OUTPUT_DIR'])
if rc1 == 0:
rc2 = resource_update(os.getcwd(), config['BUILD_DEBUG_OUTPUT_DIR'])
if rc2 == 0:
rc = 0
elif value.startswith('r'):
rc = resource_update(os.getcwd(), config['BUILD_RELEASE_OUTPUT_DIR'])
elif value.startswith('d'):
rc = resource_update(os.getcwd(), config['BUILD_DEBUG_OUTPUT_DIR'])
conclusion("RESOURCE UPDATE", rc)
elif command_name == 'clean':
if value == None:
value = default
print ('[>] Cleaning workspace, mode: {}'.format(value))
if os.path.isdir(config['BUILD_RELEASE_OUTPUT_DIR']):
shutil.rmtree(config['BUILD_RELEASE_OUTPUT_DIR'])
if os.path.isdir(config['BUILD_DEBUG_OUTPUT_DIR']):
shutil.rmtree(config['BUILD_DEBUG_OUTPUT_DIR'])
if value == 'all':
if os.path.isdir(config['INCLUDE_DIR']):
shutil.rmtree(config['INCLUDE_DIR'])
if os.path.isdir(config['LIB_DIR']):
shutil.rmtree(config['LIB_DIR'])
print ('[>] Done!')
conclusion("CLEAN", rc)
elif command_name == 'configure':
rc = 0
if value == None or value == 'release':
btype = 'Release'
print ('[>] Loading CMakeLists for build type {}...'.format(btype))
rc = configure(btype, config['BUILD_RELEASE_OUTPUT_DIR'], clean_configure=True)
print ('[>] Done!')
if rc == 0:
if value == None or value == 'debug':
btype = 'Debug'
print ('[>] Loading CMakeLists for build type {}...'.format(btype))
rc = configure(btype, config['BUILD_DEBUG_OUTPUT_DIR'], clean_configure=True)
print ('[>] Done!')
conclusion("CONFIGURE", rc)
if __name__ == '__main__':
with open(CONFIG_PATH, 'r') as f:
# Read config file
configJson = f.read()
config = json.loads(configJson)
params = extract_params(sys.argv[1:])
for param in params:
for cmd in config['COMMANDS']:
if not (cmd['NAME'] == param or cmd['SHORT'] == param):
continue
name = cmd['NAME']
value = params[param]
if not value == None and value not in cmd['VALUES']:
print ('[#] Invalid parameter "{}" to argument "{}"'.format(value, name))
break
run (name, value, None if len(cmd['VALUES']) == 0 else cmd['VALUES'][0], config)