OLD | NEW |
1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
2 # | 2 # |
3 # Copyright 2013 The Chromium Authors. All rights reserved. | 3 # Copyright 2013 The Chromium Authors. All rights reserved. |
4 # Use of this source code is governed by a BSD-style license that can be | 4 # Use of this source code is governed by a BSD-style license that can be |
5 # found in the LICENSE file. | 5 # found in the LICENSE file. |
6 | 6 |
7 """Creates symlinks to native libraries for an APK. | 7 """Creates symlinks to native libraries for an APK. |
8 | 8 |
9 The native libraries should have previously been pushed to the device (in | 9 The native libraries should have previously been pushed to the device (in |
10 options.target_dir). This script then creates links in an apk's lib/ folder to | 10 options.target_dir). This script then creates links in an apk's lib/ folder to |
11 those native libraries. | 11 those native libraries. |
12 """ | 12 """ |
13 | 13 |
14 import optparse | 14 import optparse |
15 import os | 15 import os |
16 import sys | 16 import sys |
17 | 17 |
18 from util import build_device | 18 from util import build_device |
19 from util import build_utils | 19 from util import build_utils |
20 | 20 |
21 BUILD_ANDROID_DIR = os.path.join(os.path.dirname(__file__), '..') | 21 BUILD_ANDROID_DIR = os.path.abspath( |
| 22 os.path.join(os.path.dirname(__file__), '..')) |
22 sys.path.append(BUILD_ANDROID_DIR) | 23 sys.path.append(BUILD_ANDROID_DIR) |
23 | 24 |
| 25 import devil_chromium |
24 from devil.android import apk_helper | 26 from devil.android import apk_helper |
25 from pylib import constants | 27 from pylib import constants |
26 | 28 |
27 def RunShellCommand(device, cmd): | 29 def RunShellCommand(device, cmd): |
28 output = device.RunShellCommand(cmd) | 30 output = device.RunShellCommand(cmd) |
29 | 31 |
30 if output: | 32 if output: |
31 raise Exception( | 33 raise Exception( |
32 'Unexpected output running command: ' + cmd + '\n' + | 34 'Unexpected output running command: ' + cmd + '\n' + |
33 '\n'.join(output)) | 35 '\n'.join(output)) |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
89 help='Path on the device to push the created symlink script.') | 91 help='Path on the device to push the created symlink script.') |
90 parser.add_option('--libraries', | 92 parser.add_option('--libraries', |
91 help='List of native libraries.') | 93 help='List of native libraries.') |
92 parser.add_option('--target-dir', | 94 parser.add_option('--target-dir', |
93 help='Device directory that contains the target libraries for symlinks.') | 95 help='Device directory that contains the target libraries for symlinks.') |
94 parser.add_option('--stamp', help='Path to touch on success.') | 96 parser.add_option('--stamp', help='Path to touch on success.') |
95 parser.add_option('--build-device-configuration', | 97 parser.add_option('--build-device-configuration', |
96 help='Path to build device configuration.') | 98 help='Path to build device configuration.') |
97 parser.add_option('--configuration-name', | 99 parser.add_option('--configuration-name', |
98 help='The build CONFIGURATION_NAME') | 100 help='The build CONFIGURATION_NAME') |
| 101 parser.add_option('--output-directory', |
| 102 help='The output directory') |
99 options, _ = parser.parse_args(args) | 103 options, _ = parser.parse_args(args) |
100 | 104 |
101 required_options = ['apk', 'libraries', 'script_host_path', | 105 required_options = ['apk', 'libraries', 'script_host_path', |
102 'script_device_path', 'target_dir', 'configuration_name'] | 106 'script_device_path', 'target_dir', 'configuration_name'] |
103 build_utils.CheckOptions(options, parser, required=required_options) | 107 build_utils.CheckOptions(options, parser, required=required_options) |
104 constants.SetBuildType(options.configuration_name) | 108 constants.SetBuildType(options.configuration_name) |
105 | 109 |
| 110 devil_chromium.Initialize( |
| 111 output_directory=os.path.abspath(options.output_directory)) |
| 112 |
106 CreateSymlinkScript(options) | 113 CreateSymlinkScript(options) |
107 TriggerSymlinkScript(options) | 114 TriggerSymlinkScript(options) |
108 | 115 |
109 if options.stamp: | 116 if options.stamp: |
110 build_utils.Touch(options.stamp) | 117 build_utils.Touch(options.stamp) |
111 | 118 |
112 | 119 |
113 if __name__ == '__main__': | 120 if __name__ == '__main__': |
114 sys.exit(main(sys.argv[1:])) | 121 sys.exit(main(sys.argv[1:])) |
OLD | NEW |