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

Unified Diff: tools-webrtc/ios/build_ios_libs.py

Issue 2682223004: Support selecting architectures in iOS build script (Closed)
Patch Set: Created 3 years, 10 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 | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools-webrtc/ios/build_ios_libs.py
diff --git a/tools-webrtc/ios/build_ios_libs.py b/tools-webrtc/ios/build_ios_libs.py
index 550c7a1b70bcda95f7329d8319a3d7758be2c83c..68b586a256597394a5d9688de6116f18df3d6df2 100755
--- a/tools-webrtc/ios/build_ios_libs.py
+++ b/tools-webrtc/ios/build_ios_libs.py
@@ -31,7 +31,7 @@ SDK_OUTPUT_DIR = os.path.join(WEBRTC_BASE_DIR, 'out_ios_libs')
SDK_LIB_NAME = 'librtc_sdk_objc.a'
SDK_FRAMEWORK_NAME = 'WebRTC.framework'
-ENABLED_ARCHITECTURES = ['arm', 'arm64', 'x64']
+DEFAULT_ARCHS = ['arm64', 'arm', 'x64', 'x86']
IOS_DEPLOYMENT_TARGET = '8.0'
LIBVPX_BUILD_VP9 = False
CUSTOM_GN_OPTS = [] # example: ['some_option=foo bar', 'other_option=true']
@@ -47,6 +47,8 @@ def _ParseArgs():
choices=['debug', 'release'],
help='The build config. Can be "debug" or "release". '
'Defaults to "release".')
+ parser.add_argument('--arch', default=DEFAULT_ARCHS, nargs='+',
+ help='Architectures to build. Defaults to %(default)s.')
parser.add_argument('-c', '--clean', action='store_true', default=False,
help='Removes the previously generated build output, if any.')
parser.add_argument('-o', '--output-dir', default=SDK_OUTPUT_DIR,
@@ -135,67 +137,61 @@ def main():
_CleanArtifacts(args.output_dir)
return 0
+ architectures = list(args.arch)
kthelgason 2017/02/09 12:27:53 Maybe make sure that the list only contains archit
oprypin_webrtc 2017/02/09 12:39:47 How can I determine what makes sense? Limit it onl
kjellander_webrtc 2017/02/09 13:24:04 There are only those four today, so you could vali
kthelgason 2017/02/09 13:36:13 Yeah, I was thinking something like: architectures
oprypin_webrtc 2017/02/11 21:37:00 Done.
+ # Ignoring x86 except for static libraries for now because of a GN build issue
+ # where the generated dynamic framework has the wrong architectures.
+ if 'x86' in architectures and args.build_type != 'static_only':
+ architectures.remove('x86')
+
# Build all architectures.
- for arch in ENABLED_ARCHITECTURES:
+ for arch in architectures:
BuildWebRTC(args.output_dir, arch, args.build_config, args.build_type,
IOS_DEPLOYMENT_TARGET, LIBVPX_BUILD_VP9, args.bitcode,
CUSTOM_GN_OPTS)
- # Ignoring x86 except for static libraries for now because of a GN build issue
- # where the generated dynamic framework has the wrong architectures.
-
# Create FAT archive.
if args.build_type == 'static_only':
- BuildWebRTC(args.output_dir, 'x86', args.build_config, args.build_type,
- IOS_DEPLOYMENT_TARGET, LIBVPX_BUILD_VP9, args.bitcode,
- CUSTOM_GN_OPTS)
-
- arm_lib_path = os.path.join(args.output_dir, 'arm_libs', SDK_LIB_NAME)
- arm64_lib_path = os.path.join(args.output_dir, 'arm64_libs', SDK_LIB_NAME)
- x64_lib_path = os.path.join(args.output_dir, 'x64_libs', SDK_LIB_NAME)
- x86_lib_path = os.path.join(args.output_dir, 'x86_libs', SDK_LIB_NAME)
-
+ lib_paths = [os.path.join(args.output_dir, arch + '_libs', SDK_LIB_NAME)
+ for arch in architectures]
+ out_lib_path = os.path.join(args.output_dir, SDK_LIB_NAME)
# Combine the slices.
- cmd = ['lipo', arm_lib_path, arm64_lib_path, x64_lib_path, x86_lib_path,
- '-create', '-output', os.path.join(args.output_dir, SDK_LIB_NAME)]
+ cmd = ['lipo'] + lib_paths + ['-create', '-output', out_lib_path]
_RunCommand(cmd)
elif args.build_type == 'framework':
- arm_lib_path = os.path.join(args.output_dir, 'arm_libs')
- arm64_lib_path = os.path.join(args.output_dir, 'arm64_libs')
- x64_lib_path = os.path.join(args.output_dir, 'x64_libs')
+ lib_paths = [os.path.join(args.output_dir, arch + '_libs')
+ for arch in architectures]
# Combine the slices.
dylib_path = os.path.join(SDK_FRAMEWORK_NAME, 'WebRTC')
+ # Dylibs will be combined, all other files are the same across archs.
# Use distutils instead of shutil to support merging folders.
distutils.dir_util.copy_tree(
- os.path.join(arm64_lib_path, SDK_FRAMEWORK_NAME),
+ os.path.join(lib_paths[0], SDK_FRAMEWORK_NAME),
os.path.join(args.output_dir, SDK_FRAMEWORK_NAME))
try:
os.remove(os.path.join(args.output_dir, dylib_path))
except OSError:
pass
logging.info('Merging framework slices.')
- cmd = ['lipo', os.path.join(arm_lib_path, dylib_path),
- os.path.join(arm64_lib_path, dylib_path),
- os.path.join(x64_lib_path, dylib_path),
- '-create', '-output', os.path.join(args.output_dir, dylib_path)]
+ dylib_paths = [os.path.join(path, dylib_path) for path in lib_paths]
+ out_dylib_path = os.path.join(args.output_dir, dylib_path)
+ cmd = ['lipo'] + dylib_paths + ['-create', '-output', out_dylib_path]
_RunCommand(cmd)
# Merge the dSYM slices.
dsym_path = os.path.join('WebRTC.dSYM', 'Contents', 'Resources', 'DWARF',
'WebRTC')
- distutils.dir_util.copy_tree(os.path.join(arm64_lib_path, 'WebRTC.dSYM'),
+ distutils.dir_util.copy_tree(os.path.join(lib_paths[0], 'WebRTC.dSYM'),
os.path.join(args.output_dir, 'WebRTC.dSYM'))
try:
os.remove(os.path.join(args.output_dir, dsym_path))
except OSError:
pass
logging.info('Merging dSYM slices.')
- cmd = ['lipo', os.path.join(arm_lib_path, dsym_path),
- os.path.join(arm64_lib_path, dsym_path),
- os.path.join(x64_lib_path, dsym_path),
- '-create', '-output', os.path.join(args.output_dir, dsym_path)]
+ dsym_paths = [os.path.join(path, dsym_path) for path in lib_paths]
+ out_dsym_path = os.path.join(args.output_dir, dsym_path)
+ cmd = ['lipo'] + dsym_paths + ['-create', '-output', out_dsym_path]
_RunCommand(cmd)
# Modify the version number.
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698