diff options
author | Zachary Waldowski <zwaldowski@gmail.com> | 2012-04-11 22:39:46 -0400 |
---|---|---|
committer | Anthony Green <green@moxielogic.com> | 2012-04-11 22:39:46 -0400 |
commit | 39e6a5860416f7bad992149817e1da1ba7c460d4 (patch) | |
tree | ac35b4681db887a891001c33e0f9943a0e367f83 /generate-ios-source-and-headers.py | |
parent | 853cc722a16f8d1254573ef3bb73c7b8f3d8a110 (diff) | |
download | libffi-39e6a5860416f7bad992149817e1da1ba7c460d4.tar.gz |
More mac/ios build improvements
Diffstat (limited to 'generate-ios-source-and-headers.py')
-rw-r--r-- | generate-ios-source-and-headers.py | 75 |
1 files changed, 29 insertions, 46 deletions
diff --git a/generate-ios-source-and-headers.py b/generate-ios-source-and-headers.py index 835a5f3..c2bca73 100644 --- a/generate-ios-source-and-headers.py +++ b/generate-ios-source-and-headers.py @@ -1,19 +1,17 @@ #!/usr/bin/env python + import subprocess import re import os import errno import collections import sys -#developer_path = - class Platform(object): pass sdk_re = re.compile(r'.*-sdk ([a-zA-Z0-9.]*)') - def sdkinfo(sdkname): ret = {} for line in subprocess.Popen(['xcodebuild', '-sdk', sdkname, '-version'], stdout=subprocess.PIPE).stdout: @@ -23,16 +21,6 @@ def sdkinfo(sdkname): ret[k] = v return ret -def mkdir_p(path): - try: - os.makedirs(path) - except OSError as exc: # Python >2.5 - if exc.errno == errno.EEXIST: - pass - else: - raise - - sim_sdk_info = sdkinfo('iphonesimulator') device_sdk_info = sdkinfo('iphoneos') @@ -54,7 +42,7 @@ sim_sdk, device_sdk = latest_sdks() class simulator_platform(Platform): sdk='iphonesimulator' arch = 'i386' - short_arch = arch + name = 'simulator' triple = 'i386-apple-darwin10' sdkroot = sim_sdk_info['Path'] @@ -63,8 +51,8 @@ class simulator_platform(Platform): class device_platform(Platform): sdk='iphoneos' + name = 'ios' arch = 'armv7' - short_arch = 'arm' triple = 'arm-apple-darwin10' sdkroot = device_sdk_info['Path'] @@ -73,7 +61,9 @@ class device_platform(Platform): def move_file(src_dir, dst_dir, filename, file_suffix=None, prefix='', suffix=''): - mkdir_p(dst_dir) + if not os.path.exists(dst_dir): + os.makedirs(dst_dir) + out_filename = filename if file_suffix: @@ -130,38 +120,31 @@ def build_target(platform): def xcrun_cmd(cmd): return subprocess.check_output(['xcrun', '-sdk', platform.sdkroot, '-find', cmd]).strip() - build_dir = 'build_' + platform.short_arch - mkdir_p(build_dir) - env = dict(CC=xcrun_cmd('clang'), - LD=xcrun_cmd('ld'), - CFLAGS='-arch %s -isysroot %s -miphoneos-version-min=4.3' % (platform.arch, platform.sdkroot)) - working_dir=os.getcwd() - try: - os.chdir(build_dir) - subprocess.check_call(['../configure', '-host', platform.triple], env=env) - move_source_tree('.', None, '../ios/include', - arch=platform.short_arch, - prefix=platform.prefix, - suffix=platform.suffix) - move_source_tree('./include', None, '../ios/include', - arch=platform.short_arch, - prefix=platform.prefix, - suffix=platform.suffix) - finally: - os.chdir(working_dir) - - for header_name, archs in headers_seen.iteritems(): - basename, suffix = os.path.splitext(header_name) - -def make_tramp(): - with open('src/arm/trampoline.S', 'w') as tramp_out: - p = subprocess.Popen(['bash', 'src/arm/gentramp.sh'], stdout=tramp_out) - p.wait() - + build_dir = 'build_' + platform.name + if not os.path.exists(build_dir): + os.makedirs(build_dir) + env = dict(CC=xcrun_cmd('clang'), + LD=xcrun_cmd('ld'), + CFLAGS='-arch %s -isysroot %s -miphoneos-version-min=4.0' % (platform.arch, platform.sdkroot)) + working_dir=os.getcwd() + try: + os.chdir(build_dir) + subprocess.check_call(['../configure', '-host', platform.triple], env=env) + move_source_tree('.', None, '../ios/include', + arch=platform.arch, + prefix=platform.prefix, + suffix=platform.suffix) + move_source_tree('./include', None, '../ios/include', + arch=platform.arch, + prefix=platform.prefix, + suffix=platform.suffix) + finally: + os.chdir(working_dir) + + for header_name, archs in headers_seen.iteritems(): + basename, suffix = os.path.splitext(header_name) def main(): - make_tramp() - move_source_tree('src', 'ios/src', 'ios/include') move_source_tree('include', None, 'ios/include') build_target(simulator_platform) |