| 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.abspath( | 21 BUILD_ANDROID_DIR = os.path.join(os.path.dirname(__file__), '..') |
| 22 os.path.join(os.path.dirname(__file__), '..')) | |
| 23 sys.path.append(BUILD_ANDROID_DIR) | 22 sys.path.append(BUILD_ANDROID_DIR) |
| 24 | 23 |
| 25 import devil_chromium | |
| 26 from devil.android import apk_helper | 24 from devil.android import apk_helper |
| 27 from pylib import constants | 25 from pylib import constants |
| 28 | 26 |
| 29 def RunShellCommand(device, cmd): | 27 def RunShellCommand(device, cmd): |
| 30 output = device.RunShellCommand(cmd) | 28 output = device.RunShellCommand(cmd) |
| 31 | 29 |
| 32 if output: | 30 if output: |
| 33 raise Exception( | 31 raise Exception( |
| 34 'Unexpected output running command: ' + cmd + '\n' + | 32 'Unexpected output running command: ' + cmd + '\n' + |
| 35 '\n'.join(output)) | 33 '\n'.join(output)) |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 91 help='Path on the device to push the created symlink script.') | 89 help='Path on the device to push the created symlink script.') |
| 92 parser.add_option('--libraries', | 90 parser.add_option('--libraries', |
| 93 help='List of native libraries.') | 91 help='List of native libraries.') |
| 94 parser.add_option('--target-dir', | 92 parser.add_option('--target-dir', |
| 95 help='Device directory that contains the target libraries for symlinks.') | 93 help='Device directory that contains the target libraries for symlinks.') |
| 96 parser.add_option('--stamp', help='Path to touch on success.') | 94 parser.add_option('--stamp', help='Path to touch on success.') |
| 97 parser.add_option('--build-device-configuration', | 95 parser.add_option('--build-device-configuration', |
| 98 help='Path to build device configuration.') | 96 help='Path to build device configuration.') |
| 99 parser.add_option('--configuration-name', | 97 parser.add_option('--configuration-name', |
| 100 help='The build CONFIGURATION_NAME') | 98 help='The build CONFIGURATION_NAME') |
| 101 parser.add_option('--output-directory', | |
| 102 help='The output directory') | |
| 103 options, _ = parser.parse_args(args) | 99 options, _ = parser.parse_args(args) |
| 104 | 100 |
| 105 required_options = ['apk', 'libraries', 'script_host_path', | 101 required_options = ['apk', 'libraries', 'script_host_path', |
| 106 'script_device_path', 'target_dir', 'configuration_name'] | 102 'script_device_path', 'target_dir', 'configuration_name'] |
| 107 build_utils.CheckOptions(options, parser, required=required_options) | 103 build_utils.CheckOptions(options, parser, required=required_options) |
| 108 constants.SetBuildType(options.configuration_name) | 104 constants.SetBuildType(options.configuration_name) |
| 109 | 105 |
| 110 devil_chromium.Initialize( | |
| 111 output_directory=os.path.abspath(options.output_directory)) | |
| 112 | |
| 113 CreateSymlinkScript(options) | 106 CreateSymlinkScript(options) |
| 114 TriggerSymlinkScript(options) | 107 TriggerSymlinkScript(options) |
| 115 | 108 |
| 116 if options.stamp: | 109 if options.stamp: |
| 117 build_utils.Touch(options.stamp) | 110 build_utils.Touch(options.stamp) |
| 118 | 111 |
| 119 | 112 |
| 120 if __name__ == '__main__': | 113 if __name__ == '__main__': |
| 121 sys.exit(main(sys.argv[1:])) | 114 sys.exit(main(sys.argv[1:])) |
| OLD | NEW |