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

Side by Side Diff: components/cronet/tools/package_ios.py

Issue 2807283002: [Cronet] Build static libcronet.a for iOS with complete dependencies. (Closed)
Patch Set: Change package_ios.py to build per architecture and skip x86. Created 3 years, 8 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
« no previous file with comments | « components/cronet/tools/hide_symbols.py ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/usr/bin/python 1 #!/usr/bin/python
2 # Copyright 2016 The Chromium Authors. All rights reserved. 2 # Copyright 2016 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 """ 6 """
7 package_ios.py - Build and Package Release and Rebug fat libraries for iOS. 7 package_ios.py - Build and Package Release and Rebug fat libraries for iOS.
8 """ 8 """
9 9
10 import argparse 10 import argparse
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after
83 framework_name, 'Headers'), 83 framework_name, 'Headers'),
84 os.path.join(out_dir, 'Headers')) 84 os.path.join(out_dir, 'Headers'))
85 85
86 86
87 def package_ios_framework_using_gn(out_dir='out/Framework', extra_options=''): 87 def package_ios_framework_using_gn(out_dir='out/Framework', extra_options=''):
88 print 'Building Cronet Dynamic Framework using gn...' 88 print 'Building Cronet Dynamic Framework using gn...'
89 89
90 # Package all builds in the output directory 90 # Package all builds in the output directory
91 os.makedirs(out_dir) 91 os.makedirs(out_dir)
92 build_dir = '' 92 build_dir = ''
93 for (build_config, gn_extra_args) in [('Debug', 'is_debug=true'), 93 for (build_config, gn_extra_args) in [('Release', 'is_debug=false enable_strip ping=true'),
94 ('Release', 'is_debug=false enable_stripping=true')]: 94 ('Debug', 'is_debug=true'),]:
95 for (target_device, target_cpu, additional_cpu) in [('os', 'arm', 'arm64'), 95 for (target_device, target_cpus) in [('os', ['arm', 'arm64']),
96 ('simulator', 'x86', 'x64')]: 96 ('simulator', ['x64'])]:
97 target_dir = '%s-iphone%s' % (build_config, target_device) 97 for target_cpu in target_cpus:
98 build_dir = os.path.join("out", target_dir) 98 target_dir = '%s-iphone%s-%s' % (build_config, target_device, target_cpu )
99 gn_args = 'target_os="ios" enable_websockets=false ' \ 99 build_dir = os.path.join("out", target_dir)
100 'is_cronet_build=true is_component_build=false ' \ 100 gn_args = 'target_os="ios" enable_websockets=false ' \
101 'disable_file_support=true disable_ftp_support=true ' \ 101 'is_cronet_build=true is_component_build=false ' \
102 'use_platform_icu_alternatives=true ' \ 102 'disable_file_support=true disable_ftp_support=true ' \
103 'disable_brotli_filter=true enable_dsyms=true ' \ 103 'use_platform_icu_alternatives=true ' \
104 'target_cpu="%s" additional_target_cpus = ["%s"] %s' % \ 104 'disable_brotli_filter=true enable_dsyms=true ' \
mef 2017/04/11 21:05:09 Using |additional_target_cpus| fails for hide_symb
Hiroshi Ichikawa 2017/04/12 04:35:25 So far I build the library in multiple architectur
mef 2017/04/12 15:57:50 Thanks for the pointer! I'll give it a try if this
105 (target_cpu, additional_cpu, gn_extra_args) 105 'target_cpu="%s" %s' % \
106 (target_cpu, gn_extra_args)
106 107
107 print 'Generating Ninja ' + gn_args 108 print 'Generating Ninja ' + gn_args
108 gn_result = run('gn gen %s --args=\'%s\'' % (build_dir, gn_args)) 109 gn_result = run('gn gen %s --args=\'%s\'' % (build_dir, gn_args))
109 if gn_result != 0: 110 if gn_result != 0:
110 return gn_result 111 return gn_result
111 112
112 print 'Building ' + build_dir 113 print 'Building ' + build_dir
113 build_result = run('ninja -C %s cronet_package' % build_dir, 114 build_result = run('ninja -C %s cronet_package' % build_dir,
114 extra_options) 115 extra_options)
115 if build_result != 0: 116 if build_result != 0:
116 return build_result 117 return build_result
117 118
118 # Copy framework. 119 # Copy framework.
119 shutil.copytree(os.path.join(build_dir, 'Cronet.framework'), 120 shutil.copytree(os.path.join(build_dir, 'Cronet.framework'),
120 os.path.join(out_dir, target_dir, 'Cronet.framework')) 121 os.path.join(out_dir, target_dir, 'Cronet.framework'))
121 # Copy symbols. 122 # Copy symbols.
122 shutil.copytree(os.path.join(build_dir, 'Cronet.dSYM'), 123 shutil.copytree(os.path.join(build_dir, 'Cronet.dSYM'),
123 os.path.join(out_dir, target_dir, 'Cronet.framework.dSYM')) 124 os.path.join(out_dir, target_dir, 'Cronet.framework.dSYM'))
125
126 # Copy static library.
127 shutil.copy2(os.path.join(build_dir, 'cronet', 'libcronet.a'),
128 os.path.join(out_dir, target_dir))
124 129
125 # Copy common files from last built package. 130 # Copy common files from last built package.
126 package_dir = os.path.join(build_dir, 'cronet') 131 package_dir = os.path.join(build_dir, 'cronet')
127 shutil.copy2(os.path.join(package_dir, 'AUTHORS'), out_dir) 132 shutil.copy2(os.path.join(package_dir, 'AUTHORS'), out_dir)
128 shutil.copy2(os.path.join(package_dir, 'LICENSE'), out_dir) 133 shutil.copy2(os.path.join(package_dir, 'LICENSE'), out_dir)
129 shutil.copy2(os.path.join(package_dir, 'VERSION'), out_dir) 134 shutil.copy2(os.path.join(package_dir, 'VERSION'), out_dir)
130 # Copy the headers. 135 # Copy the headers.
131 shutil.copytree(os.path.join(build_dir, 136 shutil.copytree(os.path.join(build_dir,
132 'Cronet.framework', 'Headers'), 137 'Cronet.framework', 'Headers'),
133 os.path.join(out_dir, 'Headers')) 138 os.path.join(out_dir, 'Headers'))
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
190 195
191 if options.gn: 196 if options.gn:
192 return package_ios_framework_using_gn(out_dir, extra_options_list) 197 return package_ios_framework_using_gn(out_dir, extra_options_list)
193 198
194 return package_ios(out_dir, "out/Release", "opt") or \ 199 return package_ios(out_dir, "out/Release", "opt") or \
195 package_ios(out_dir, "out/Debug", "dbg") 200 package_ios(out_dir, "out/Debug", "dbg")
196 201
197 202
198 if __name__ == '__main__': 203 if __name__ == '__main__':
199 sys.exit(main()) 204 sys.exit(main())
OLDNEW
« no previous file with comments | « components/cronet/tools/hide_symbols.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698