OLD | NEW |
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 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
45 build_target = 'cronet_package' | 45 build_target = 'cronet_package' |
46 target_dir = out_dir | 46 target_dir = out_dir |
47 return build(build_dir_sim, build_target) or \ | 47 return build(build_dir_sim, build_target) or \ |
48 build(build_dir_dev, build_target) or \ | 48 build(build_dir_dev, build_target) or \ |
49 copy_build_dir(target_dir, build_dir_dev + "/cronet") or \ | 49 copy_build_dir(target_dir, build_dir_dev + "/cronet") or \ |
50 lipo_libraries(target_dir, [build_dir_sim, build_dir_dev], \ | 50 lipo_libraries(target_dir, [build_dir_sim, build_dir_dev], \ |
51 "libcronet_" + build_config + ".a", \ | 51 "libcronet_" + build_config + ".a", \ |
52 "cronet/libcronet_standalone.a") | 52 "cronet/libcronet_standalone.a") |
53 | 53 |
54 | 54 |
55 def package_ios_framework(out_dir='out/Framework', extra_options=''): | 55 def package_ios_framework(out_dir, target, framework_name, extra_options=''): |
56 print 'Building Cronet Dynamic Framework...' | 56 print 'Building Cronet Dynamic Framework...' |
57 | 57 |
58 # Use Ninja to build all possible combinations. | 58 # Use Ninja to build all possible combinations. |
59 build_dirs = ['Debug-iphonesimulator', | 59 build_dirs = ['Debug-iphonesimulator', |
60 'Debug-iphoneos', | 60 'Debug-iphoneos', |
61 'Release-iphonesimulator', | 61 'Release-iphonesimulator', |
62 'Release-iphoneos'] | 62 'Release-iphoneos'] |
63 for build_dir in build_dirs: | 63 for build_dir in build_dirs: |
64 print 'Building ' + build_dir | 64 print 'Building ' + build_dir |
65 build_result = run('ninja -C out/' + build_dir + ' cronet_framework', | 65 build_result = run('ninja -C out/' + build_dir + ' ' + target, |
66 extra_options) | 66 extra_options) |
67 if build_result != 0: | 67 if build_result != 0: |
68 return build_result | 68 return build_result |
69 | 69 |
70 # Package all builds in the output directory | 70 # Package all builds in the output directory |
71 os.makedirs(out_dir) | 71 os.makedirs(out_dir) |
72 for build_dir in build_dirs: | 72 for build_dir in build_dirs: |
73 shutil.copytree(os.path.join('out', build_dir, 'Cronet.framework'), | 73 shutil.copytree(os.path.join('out', build_dir, framework_name), |
74 os.path.join(out_dir, build_dir, 'Cronet.framework')) | 74 os.path.join(out_dir, build_dir, framework_name)) |
75 if 'Release' in build_dir: | 75 if 'Release' in build_dir: |
76 shutil.copytree(os.path.join('out', build_dir, 'Cronet.framework.dSYM'), | 76 shutil.copytree(os.path.join('out', build_dir, framework_name + '.dSYM'), |
77 os.path.join(out_dir, build_dir, 'Cronet.framework.dSYM')) | 77 os.path.join(out_dir, build_dir, |
| 78 framework_name + '.dSYM')) |
78 # Copy the version file | 79 # Copy the version file |
79 shutil.copy2('chrome/VERSION', out_dir) | 80 shutil.copy2('chrome/VERSION', out_dir) |
80 # Copy the headers | 81 # Copy the headers |
81 shutil.copytree(os.path.join(out_dir, build_dirs[0], | 82 shutil.copytree(os.path.join(out_dir, build_dirs[0], |
82 'Cronet.framework', 'Headers'), | 83 framework_name, 'Headers'), |
83 os.path.join(out_dir, 'Headers')) | 84 os.path.join(out_dir, 'Headers')) |
84 | 85 |
85 | 86 |
86 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=''): |
87 print 'Building Cronet Dynamic Framework using gn...' | 88 print 'Building Cronet Dynamic Framework using gn...' |
88 | 89 |
89 # Package all builds in the output directory | 90 # Package all builds in the output directory |
90 os.makedirs(out_dir) | 91 os.makedirs(out_dir) |
91 build_dir = '' | 92 build_dir = '' |
92 for (build_config, gn_extra_args) in [('Debug', 'is_debug=true'), | 93 for (build_config, gn_extra_args) in [('Debug', 'is_debug=true'), |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
127 shutil.copy2(os.path.join(package_dir, 'LICENSE'), out_dir) | 128 shutil.copy2(os.path.join(package_dir, 'LICENSE'), out_dir) |
128 shutil.copy2(os.path.join(package_dir, 'VERSION'), out_dir) | 129 shutil.copy2(os.path.join(package_dir, 'VERSION'), out_dir) |
129 # Copy the headers. | 130 # Copy the headers. |
130 shutil.copytree(os.path.join(build_dir, | 131 shutil.copytree(os.path.join(build_dir, |
131 'Cronet.framework', 'Headers'), | 132 'Cronet.framework', 'Headers'), |
132 os.path.join(out_dir, 'Headers')) | 133 os.path.join(out_dir, 'Headers')) |
133 print 'Cronet dynamic framework is packaged into %s' % out_dir | 134 print 'Cronet dynamic framework is packaged into %s' % out_dir |
134 | 135 |
135 | 136 |
136 def main(): | 137 def main(): |
137 parser = argparse.ArgumentParser() | 138 description = ( |
| 139 '1. To build Cronet.framework call:\n' |
| 140 'package_ios.py --framework out/Frameworks\n' |
| 141 '2. To build CrNet.framework call:\n' |
| 142 'package_ios.py --crnet out/crnet\n' |
| 143 ) |
| 144 parser = argparse.ArgumentParser(description=description) |
| 145 |
138 parser.add_argument('out_dir', nargs=1, help='path to output directory') | 146 parser.add_argument('out_dir', nargs=1, help='path to output directory') |
139 parser.add_argument('-g', '--gn', action='store_true', | 147 parser.add_argument('-g', '--gn', action='store_true', |
140 help='build using gn') | 148 help='build using gn') |
141 parser.add_argument('-d', '--debug', action='store_true', | 149 parser.add_argument('-d', '--debug', action='store_true', |
142 help='use release configuration') | 150 help='use release configuration') |
143 parser.add_argument('-r', '--release', action='store_true', | 151 parser.add_argument('-r', '--release', action='store_true', |
144 help='use release configuration') | 152 help='use release configuration') |
145 parser.add_argument('--framework', action='store_true', | 153 parser.add_argument('--framework', action='store_true', |
146 help='build Cronet dynamic framework') | 154 help='build Cronet dynamic framework') |
| 155 parser.add_argument('--crnet', action='store_true', |
| 156 help='build CrNet dynamic framework') |
| 157 parser.add_argument('--use_full_icu', action='store_true', |
| 158 help='use full version of ICU instead of \ |
| 159 platform ICU alternative.') |
147 | 160 |
148 options, extra_options_list = parser.parse_known_args() | 161 options, extra_options_list = parser.parse_known_args() |
149 print options | 162 print options |
150 print extra_options_list | 163 print extra_options_list |
151 | 164 |
152 out_dir = options.out_dir[0] | 165 out_dir = options.out_dir[0] |
153 | 166 |
154 # Make sure that the output directory does not exist | 167 # Make sure that the output directory does not exist |
155 if os.path.exists(out_dir): | 168 if os.path.exists(out_dir): |
156 print >>sys.stderr, 'The output directory already exists: ' + out_dir | 169 print >>sys.stderr, 'The output directory already exists: ' + out_dir |
157 return 1 | 170 return 1 |
158 | 171 |
| 172 use_platform_icu_alternatives = 'use_platform_icu_alternatives=1' \ |
| 173 if not options.use_full_icu else 'use_platform_icu_alternatives=0' |
| 174 |
159 gyp_defines = 'GYP_DEFINES="OS=ios enable_websockets=0 '+ \ | 175 gyp_defines = 'GYP_DEFINES="OS=ios enable_websockets=0 '+ \ |
160 'disable_file_support=1 disable_ftp_support=1 '+ \ | 176 'disable_file_support=1 disable_ftp_support=1 '+ \ |
161 'enable_errorprone=1 use_platform_icu_alternatives=1 ' + \ | 177 'enable_errorprone=1 disable_brotli_filter=1 chromium_ios_signing=0 ' + \ |
162 'disable_brotli_filter=1 chromium_ios_signing=0 ' + \ | 178 'target_subarch=both ' + use_platform_icu_alternatives + '"' |
163 'target_subarch=both"' | 179 |
164 if not options.gn: | 180 if not options.gn: |
165 run (gyp_defines + ' gclient runhooks') | 181 run (gyp_defines + ' gclient runhooks') |
166 | 182 |
167 if options.framework: | 183 if options.framework: |
168 return package_ios_framework(out_dir, extra_options_list) | 184 return package_ios_framework(out_dir, 'cronet_framework', |
| 185 'Cronet.framework', extra_options_list) |
| 186 |
| 187 if options.crnet: |
| 188 return package_ios_framework(out_dir, 'crnet_framework', |
| 189 'CrNet.framework', extra_options_list) |
169 | 190 |
170 if options.gn: | 191 if options.gn: |
171 return package_ios_framework_using_gn(out_dir, extra_options_list) | 192 return package_ios_framework_using_gn(out_dir, extra_options_list) |
172 | 193 |
173 return package_ios(out_dir, "out/Release", "opt") or \ | 194 return package_ios(out_dir, "out/Release", "opt") or \ |
174 package_ios(out_dir, "out/Debug", "dbg") | 195 package_ios(out_dir, "out/Debug", "dbg") |
175 | 196 |
176 | 197 |
177 if __name__ == '__main__': | 198 if __name__ == '__main__': |
178 sys.exit(main()) | 199 sys.exit(main()) |
OLD | NEW |