2 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file.
6 """Shim to run nacl toolchain download script only if there is a nacl dir."""
14 # Exit early if disable_nacl=1.
15 if 'disable_nacl=1' in os
.environ
.get('GYP_DEFINES', ''):
17 script_dir
= os
.path
.dirname(os
.path
.abspath(__file__
))
18 src_dir
= os
.path
.dirname(script_dir
)
19 nacl_dir
= os
.path
.join(src_dir
, 'native_client')
20 nacl_build_dir
= os
.path
.join(nacl_dir
, 'build')
21 package_version_dir
= os
.path
.join(nacl_build_dir
, 'package_version')
22 package_version
= os
.path
.join(package_version_dir
, 'package_version.py')
23 if not os
.path
.exists(package_version
):
24 print "Can't find '%s'" % package_version
25 print 'Presumably you are intentionally building without NativeClient.'
26 print 'Skipping NativeClient toolchain download.'
28 sys
.path
.insert(0, package_version_dir
)
29 import package_version
32 # We remove this --optional-pnacl argument, and instead replace it with
33 # --no-pnacl for most cases. However, if the bot name is an sdk
34 # bot then we will go ahead and download it. This prevents increasing the
35 # gclient sync time for developers, or standard Chrome bots.
36 if '--optional-pnacl' in args
:
37 args
.remove('--optional-pnacl')
39 buildbot_name
= os
.environ
.get('BUILDBOT_BUILDERNAME', '')
40 if 'pnacl' in buildbot_name
and 'sdk' in buildbot_name
:
43 print '\n*** DOWNLOADING PNACL TOOLCHAIN ***\n'
45 args
.extend(['--exclude', 'pnacl_newlib'])
47 # Only download the ARM gcc toolchain if we are building for ARM
48 # TODO(olonho): we need to invent more reliable way to get build
49 # configuration info, to know if we're building for ARM.
50 if 'target_arch=arm' not in os
.environ
.get('GYP_DEFINES', ''):
51 args
.extend(['--exclude', 'nacl_arm_newlib'])
53 args
.extend(['--mode', 'nacl_core_sdk'])
55 package_version
.main(args
)
57 # Because we are no longer extracting the toolchain, it is best to delete
58 # the old extracted ones so that no stale toolchains are left behind. This
59 # also would catch any stale code that happens to work because it is using
60 # an old extracted toolchain that was left behind.
61 toolchain_dir
= os
.path
.join(nacl_dir
, 'toolchain')
62 for toolchain_item
in os
.listdir(toolchain_dir
):
63 toolchain_path
= os
.path
.join(toolchain_dir
, toolchain_item
)
64 if os
.path
.isdir(toolchain_path
) and not toolchain_item
.startswith('.'):
65 shutil
.rmtree(toolchain_path
)
70 if __name__
== '__main__':
71 sys
.exit(Main(sys
.argv
[1:]))