Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(411)

Side by Side Diff: build/android/gyp/push_libraries.py

Issue 456493002: Add native libraries to gn apks (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 """Pushes native libraries to a device. 7 """Pushes native libraries to a device.
8 8
9 """ 9 """
10 10
11 import optparse 11 import optparse
12 import os 12 import os
13 import sys 13 import sys
14 14
15 BUILD_ANDROID_DIR = os.path.join(os.path.dirname(__file__), os.pardir) 15 BUILD_ANDROID_DIR = os.path.join(os.path.dirname(__file__), os.pardir)
16 sys.path.append(BUILD_ANDROID_DIR) 16 sys.path.append(BUILD_ANDROID_DIR)
17 17
18 from pylib import constants 18 from pylib import constants
19 19
20 from util import build_device 20 from util import build_device
21 from util import build_utils 21 from util import build_utils
22 from util import md5_check 22 from util import md5_check
23 23
24 def DoPush(options): 24 def DoPush(options):
25 libraries = build_utils.ReadJson(options.libraries_json) 25 libraries = build_utils.ParseGypList(options.libraries)
26 26
27 device = build_device.GetBuildDeviceFromPath( 27 device = build_device.GetBuildDeviceFromPath(
28 options.build_device_configuration) 28 options.build_device_configuration)
29 if not device: 29 if not device:
30 return 30 return
31 31
32 serial_number = device.GetSerialNumber() 32 serial_number = device.GetSerialNumber()
33 # A list so that it is modifiable in Push below. 33 # A list so that it is modifiable in Push below.
34 needs_directory = [True] 34 needs_directory = [True]
35 for lib in libraries: 35 for lib in libraries:
36 device_path = os.path.join(options.device_dir, lib) 36 device_path = os.path.join(options.device_dir, lib)
37 host_path = os.path.join(options.libraries_dir, lib) 37 host_path = os.path.join(options.libraries_dir, lib)
38 38
39 def Push(): 39 def Push():
40 if needs_directory: 40 if needs_directory:
41 device.RunShellCommand('mkdir -p ' + options.device_dir) 41 device.RunShellCommand('mkdir -p ' + options.device_dir)
42 needs_directory[:] = [] # = False 42 needs_directory[:] = [] # = False
43 device.PushChangedFiles(host_path, device_path) 43 device.PushChangedFiles(host_path, device_path)
44 44
45 record_path = '%s.%s.push.md5.stamp' % (host_path, serial_number) 45 record_path = '%s.%s.push.md5.stamp' % (host_path, serial_number)
46 md5_check.CallAndRecordIfStale( 46 md5_check.CallAndRecordIfStale(
47 Push, 47 Push,
48 record_path=record_path, 48 record_path=record_path,
49 input_paths=[host_path], 49 input_paths=[host_path],
50 input_strings=[device_path]) 50 input_strings=[device_path])
51 51
52 52
53 def main(): 53 def main(args):
54 args = build_utils.ExpandFileArgs(args)
54 parser = optparse.OptionParser() 55 parser = optparse.OptionParser()
55 parser.add_option('--libraries-dir', 56 parser.add_option('--libraries-dir',
56 help='Directory that contains stripped libraries.') 57 help='Directory that contains stripped libraries.')
57 parser.add_option('--device-dir', 58 parser.add_option('--device-dir',
58 help='Device directory to push the libraries to.') 59 help='Device directory to push the libraries to.')
59 parser.add_option('--libraries-json', 60 parser.add_option('--libraries',
60 help='Path to the json list of native libraries.') 61 help='List of native libraries.')
61 parser.add_option('--stamp', help='Path to touch on success.') 62 parser.add_option('--stamp', help='Path to touch on success.')
62 parser.add_option('--build-device-configuration', 63 parser.add_option('--build-device-configuration',
63 help='Path to build device configuration.') 64 help='Path to build device configuration.')
64 parser.add_option('--configuration-name', 65 parser.add_option('--configuration-name',
65 help='The build CONFIGURATION_NAME') 66 help='The build CONFIGURATION_NAME')
66 options, _ = parser.parse_args() 67 options, _ = parser.parse_args(args)
67 68
68 required_options = ['libraries_dir', 'device_dir', 'libraries_json'] 69 required_options = ['libraries', 'device_dir', 'libraries']
69 build_utils.CheckOptions(options, parser, required=required_options) 70 build_utils.CheckOptions(options, parser, required=required_options)
70 constants.SetBuildType(options.configuration_name) 71 constants.SetBuildType(options.configuration_name)
71 72
72 DoPush(options) 73 DoPush(options)
73 74
74 if options.stamp: 75 if options.stamp:
75 build_utils.Touch(options.stamp) 76 build_utils.Touch(options.stamp)
76 77
77 78
78 if __name__ == '__main__': 79 if __name__ == '__main__':
79 sys.exit(main()) 80 sys.exit(main(sys.argv[1:]))
OLDNEW
« no previous file with comments | « build/android/gyp/pack_arm_relocations.py ('k') | build/android/gyp/strip_library_for_device.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698