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

Unified Diff: ios/web_view/tools/build.py

Issue 2941683002: Add script to generate CronetChromeWebView.framework (Closed)
Patch Set: Add dep CL. Created 3 years, 6 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ios/web_view/BUILD.gn ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ios/web_view/tools/build.py
diff --git a/ios/web_view/tools/build.py b/ios/web_view/tools/build.py
new file mode 100755
index 0000000000000000000000000000000000000000..e438618ec694c0442efa67ff999b1c44112670d8
--- /dev/null
+++ b/ios/web_view/tools/build.py
@@ -0,0 +1,144 @@
+#!/usr/bin/python
+# Copyright 2017 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+"""
+Build and package CronetChromeWebView.framework
+"""
+
+import argparse
+import os
+import shutil
+import sys
+
+def target_dir_name(build_config, target_device):
+ """Creates a defult output directory name for the given build_config and
Eugene But (OOO till 7-30) 2017/06/16 03:37:18 This link has an example of comments than conform
michaeldo 2017/06/16 18:16:50 Thank you for the reference, updated function comm
+ target_device"""
+ return '%s-iphone%s' % (build_config, target_device)
+
+def build(build_config, target_device, extra_gn_options):
+ """Generates and builds CronetChromeWebView.framework for the given
+ build_config and target_device"""
+ if target_device == 'os':
+ target_cpu = 'arm'
+ additional_cpu = 'arm64'
+ else:
+ target_cpu = 'x86'
+ additional_cpu = 'x64'
+
+ if build_config == 'Debug':
+ gn_extra_args = 'is_debug=true'
Hiroshi Ichikawa 2017/06/16 07:41:59 Optional: This may be too confusing with extra_gn_
michaeldo 2017/06/16 18:16:50 I agree, I updated it to build_config_gn_args to b
+ else:
+ gn_extra_args = 'is_debug=false enable_stripping=true'
+
+ build_dir = os.path.join("out", target_dir_name(build_config, target_device))
+ gn_args = 'target_os="ios" enable_websockets=false ' \
Hiroshi Ichikawa 2017/06/16 07:41:59 It seems preferred to use parentheses than backsla
michaeldo 2017/06/16 18:16:50 Done.
+ 'is_component_build=false use_xcode_clang=false ' \
+ 'disable_file_support=true disable_ftp_support=true ' \
+ 'disable_brotli_filter=true ' \
+ 'target_cpu="%s" additional_target_cpus = ["%s"] %s %s' % \
+ (target_cpu, additional_cpu, gn_extra_args, extra_gn_options)
+
+ gn_command = 'gn gen %s --args=\'%s\'' % (build_dir, gn_args)
+ print gn_command
+ gn_result = os.system(gn_command)
+ if gn_result != 0:
+ return gn_result
+
+ ninja_command = 'ninja -C %s ios/web_view:cronet_ios_web_view_package' % \
Hiroshi Ichikawa 2017/06/16 07:41:59 Ditto.
michaeldo 2017/06/16 18:16:50 Done.
+ build_dir
+ print ninja_command
+ return os.system(ninja_command)
+
+def copy_build_products(build_config, target_device, out_dir):
+ """Copies the resulting framework and symbols to out_dir"""
+ target_dir = target_dir_name(build_config, target_device)
+ build_dir = os.path.join("out", target_dir)
+
+ # Copy framework.
+ framework_source = os.path.join(build_dir, 'CronetChromeWebView.framework')
+ framework_dest = os.path.join(out_dir, target_dir,
+ 'CronetChromeWebView.framework')
+ print 'Copying %s to %s' % (framework_source, framework_dest)
+ shutil.copytree(framework_source, framework_dest)
+
+ # Copy symbols.
+ symbols_source = os.path.join(build_dir, 'CronetChromeWebView.dSYM')
+ symbols_dest = os.path.join(out_dir, target_dir, 'CronetChromeWebView.dSYM')
+ print 'Copying %s to %s' % (symbols_source, symbols_dest)
+ shutil.copytree(symbols_source, symbols_dest)
+
+def package_framework(build_config, target_device, out_dir, extra_gn_options):
+ """Builds CronetChromeWebView.framework for the given build_config and
+ target_device and copies the result into out_dir"""
+ print '\nBuilding for %s (%s)' % (target_device, build_config)
+
+ build_result = build(build_config, target_device, extra_gn_options)
+ if build_result != 0:
+ error = 'Building %s/%s failed with code: ' % (build_config, target_device)
+ print >>sys.stderr, error, build_result
+ return build_result
+ copy_build_products(build_config, target_device, out_dir)
+ return 0
+
+def package_all_frameworks(out_dir, extra_gn_options):
+ """Builds Release and Debug versions of CronetChromeWebView.framework for both
+ iOS devices and simulator and copies the resulting frameworks into out_dir.
+ """
+ print 'Building CronetChromeWebView.framework...'
+
+ # Package all builds in the output directory
+ os.makedirs(out_dir)
+
+ if package_framework('Debug', 'simulator', out_dir, extra_gn_options) != 0:
+ return 1
+ if package_framework('Debug', 'os', out_dir, extra_gn_options) != 0:
+ return 1
+ if package_framework('Release', 'simulator', out_dir, extra_gn_options) != 0:
+ return 1
+ if package_framework('Release', 'os', out_dir, extra_gn_options) != 0:
+ return 1
+
+ # Copy common files from last built package to out_dir.
+ build_dir = os.path.join("out", target_dir_name('Release', 'os'))
+ package_dir = os.path.join(build_dir, 'cronet_ios_web_view')
+ shutil.copy2(os.path.join(package_dir, 'AUTHORS'), out_dir)
+ shutil.copy2(os.path.join(package_dir, 'LICENSE'), out_dir)
+ shutil.copy2(os.path.join(package_dir, 'VERSION'), out_dir)
+
+ print '\nSuccess! CronetChromeWebView.framework is packaged into %s' % out_dir
+
+ return 0
+
+def main():
+ description = "Build and package CronetChromeWebView.framework"
+ parser = argparse.ArgumentParser(description=description)
+
+ parser.add_argument('out_dir', nargs='?', default='out/CronetChromeWebView',
+ help='path to output directory')
+ parser.add_argument('--no_goma', action='store_true',
+ help='Prevents adding use_goma=true to the gn args.')
+
+ options, extra_options = parser.parse_known_args()
+ print options
Hiroshi Ichikawa 2017/06/16 07:41:59 Maybe prefix this output with "options: " or somet
michaeldo 2017/06/16 18:16:50 I added a comment before the options are printed.
+
+ if len(extra_options):
+ print >>sys.stderr, 'Unknown options: ', extra_options
+ return 1
+
+ out_dir = options.out_dir
+ # Make sure that the output directory does not exist
+ if os.path.exists(out_dir):
+ print >>sys.stderr, 'The output directory already exists: ' + out_dir
+ return 1
+
+ gn_options = 'use_goma=true'
Hiroshi Ichikawa 2017/06/16 07:41:59 Maybe cleaner to be one line?: gn_options = '' i
michaeldo 2017/06/16 18:16:50 Done.
+ if options.no_goma:
+ gn_options = ''
+
+ return package_all_frameworks(out_dir, gn_options)
+
+
+if __name__ == '__main__':
+ sys.exit(main())
« no previous file with comments | « ios/web_view/BUILD.gn ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698