OLD | NEW |
1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
2 # Copyright (c) 2013 The Chromium Authors. All rights reserved. | 2 # Copyright (c) 2013 The Chromium Authors. All rights reserved. |
3 # Use of this source code is governed by a BSD-style license that can be | 3 # Use of this source code is governed by a BSD-style license that can be |
4 # found in the LICENSE file. | 4 # found in the LICENSE file. |
5 | 5 |
6 import argparse | 6 import argparse |
7 import multiprocessing | 7 import multiprocessing |
8 import os | 8 import os |
9 import posixpath | 9 import posixpath |
10 import sys | 10 import sys |
(...skipping 12 matching lines...) Expand all Loading... |
23 import getos | 23 import getos |
24 | 24 |
25 | 25 |
26 MAKE = 'nacl_sdk/make_3.99.90-26-gf80222c/make.exe' | 26 MAKE = 'nacl_sdk/make_3.99.90-26-gf80222c/make.exe' |
27 LIB_DICT = { | 27 LIB_DICT = { |
28 'linux': [], | 28 'linux': [], |
29 'mac': [], | 29 'mac': [], |
30 'win': ['x86_32'] | 30 'win': ['x86_32'] |
31 } | 31 } |
32 VALID_TOOLCHAINS = [ | 32 VALID_TOOLCHAINS = [ |
| 33 'bionic', |
33 'newlib', | 34 'newlib', |
34 'clang-newlib', | 35 'clang-newlib', |
35 'glibc', | 36 'glibc', |
36 'pnacl', | 37 'pnacl', |
37 'win', | 38 'win', |
38 'linux', | 39 'linux', |
39 'mac', | 40 'mac', |
40 ] | 41 ] |
41 | 42 |
42 # Global verbosity setting. | 43 # Global verbosity setting. |
(...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
205 # build. | 206 # build. |
206 env['X86_32_CFLAGS'] = '-m32' | 207 env['X86_32_CFLAGS'] = '-m32' |
207 env['X86_32_CXXFLAGS'] = '-m32' | 208 env['X86_32_CXXFLAGS'] = '-m32' |
208 jobs = '50' | 209 jobs = '50' |
209 else: | 210 else: |
210 jobs = str(multiprocessing.cpu_count()) | 211 jobs = str(multiprocessing.cpu_count()) |
211 | 212 |
212 make_cmd = [make, '-j', jobs] | 213 make_cmd = [make, '-j', jobs] |
213 | 214 |
214 make_cmd.append('CONFIG='+config) | 215 make_cmd.append('CONFIG='+config) |
| 216 # We always ENABLE_BIONIC in case we need it. If neither --bionic nor |
| 217 # -t bionic have been provided on the command line, then VALID_TOOLCHAINS |
| 218 # will not contain a bionic target. |
| 219 make_cmd.append('ENABLE_BIONIC=1') |
215 if not deps: | 220 if not deps: |
216 make_cmd.append('IGNORE_DEPS=1') | 221 make_cmd.append('IGNORE_DEPS=1') |
217 | 222 |
218 if verbose: | 223 if verbose: |
219 make_cmd.append('V=1') | 224 make_cmd.append('V=1') |
220 | 225 |
221 if args: | 226 if args: |
222 make_cmd += args | 227 make_cmd += args |
223 else: | 228 else: |
224 make_cmd.append('TOOLCHAIN=all') | 229 make_cmd.append('TOOLCHAIN=all') |
(...skipping 19 matching lines...) Expand all Loading... |
244 parser = argparse.ArgumentParser(description=__doc__) | 249 parser = argparse.ArgumentParser(description=__doc__) |
245 parser.add_argument('-c', '--clobber', | 250 parser.add_argument('-c', '--clobber', |
246 help='Clobber project directories before copying new files', | 251 help='Clobber project directories before copying new files', |
247 action='store_true', default=False) | 252 action='store_true', default=False) |
248 parser.add_argument('-b', '--build', | 253 parser.add_argument('-b', '--build', |
249 help='Build the projects. Otherwise the projects are only copied.', | 254 help='Build the projects. Otherwise the projects are only copied.', |
250 action='store_true') | 255 action='store_true') |
251 parser.add_argument('--config', | 256 parser.add_argument('--config', |
252 help='Choose configuration to build (Debug or Release). Builds both ' | 257 help='Choose configuration to build (Debug or Release). Builds both ' |
253 'by default') | 258 'by default') |
| 259 parser.add_argument('--bionic', |
| 260 help='Enable bionic projects', action='store_true') |
254 parser.add_argument('-x', '--experimental', | 261 parser.add_argument('-x', '--experimental', |
255 help='Build experimental projects', action='store_true') | 262 help='Build experimental projects', action='store_true') |
256 parser.add_argument('-t', '--toolchain', | 263 parser.add_argument('-t', '--toolchain', |
257 help='Build using toolchain. Can be passed more than once.', | 264 help='Build using toolchain. Can be passed more than once.', |
258 action='append', default=[]) | 265 action='append', default=[]) |
259 parser.add_argument('-d', '--dest', | 266 parser.add_argument('-d', '--dest', |
260 help='Select which build destinations (project types) are valid.', | 267 help='Select which build destinations (project types) are valid.', |
261 action='append') | 268 action='append') |
262 parser.add_argument('projects', nargs='*', | 269 parser.add_argument('projects', nargs='*', |
263 help='Select which projects to build.') | 270 help='Select which projects to build.') |
(...skipping 23 matching lines...) Expand all Loading... |
287 | 294 |
288 pepper_ver = str(int(build_version.ChromeMajorVersion())) | 295 pepper_ver = str(int(build_version.ChromeMajorVersion())) |
289 pepperdir = os.path.join(OUT_DIR, 'pepper_' + pepper_ver) | 296 pepperdir = os.path.join(OUT_DIR, 'pepper_' + pepper_ver) |
290 | 297 |
291 if not options.toolchain: | 298 if not options.toolchain: |
292 # Order matters here: the default toolchain for an example's Makefile will | 299 # Order matters here: the default toolchain for an example's Makefile will |
293 # be the first toolchain in this list that is available in the example. | 300 # be the first toolchain in this list that is available in the example. |
294 # e.g. If an example supports newlib and glibc, then the default will be | 301 # e.g. If an example supports newlib and glibc, then the default will be |
295 # newlib. | 302 # newlib. |
296 options.toolchain = ['pnacl', 'newlib', 'glibc', 'host', 'clang-newlib'] | 303 options.toolchain = ['pnacl', 'newlib', 'glibc', 'host', 'clang-newlib'] |
| 304 if options.experimental or options.bionic: |
| 305 options.toolchain.append('bionic') |
297 | 306 |
298 if 'host' in options.toolchain: | 307 if 'host' in options.toolchain: |
299 options.toolchain.remove('host') | 308 options.toolchain.remove('host') |
300 options.toolchain.append(getos.GetPlatform()) | 309 options.toolchain.append(getos.GetPlatform()) |
301 Trace('Adding platform: ' + getos.GetPlatform()) | 310 Trace('Adding platform: ' + getos.GetPlatform()) |
302 | 311 |
303 ValidateToolchains(options.toolchain) | 312 ValidateToolchains(options.toolchain) |
304 | 313 |
305 filters = {} | 314 filters = {} |
306 if options.toolchain: | 315 if options.toolchain: |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
339 | 348 |
340 | 349 |
341 if __name__ == '__main__': | 350 if __name__ == '__main__': |
342 script_name = os.path.basename(sys.argv[0]) | 351 script_name = os.path.basename(sys.argv[0]) |
343 try: | 352 try: |
344 sys.exit(main(sys.argv[1:])) | 353 sys.exit(main(sys.argv[1:])) |
345 except parse_dsc.ValidationError as e: | 354 except parse_dsc.ValidationError as e: |
346 buildbot_common.ErrorExit('%s: %s' % (script_name, e)) | 355 buildbot_common.ErrorExit('%s: %s' % (script_name, e)) |
347 except KeyboardInterrupt: | 356 except KeyboardInterrupt: |
348 buildbot_common.ErrorExit('%s: interrupted' % script_name) | 357 buildbot_common.ErrorExit('%s: interrupted' % script_name) |
OLD | NEW |