summaryrefslogtreecommitdiff
path: root/generate-ios-source-and-headers.py
diff options
context:
space:
mode:
authorZachary Waldowski <zwaldowski@gmail.com>2012-04-11 22:39:46 -0400
committerAnthony Green <green@moxielogic.com>2012-04-11 22:39:46 -0400
commit39e6a5860416f7bad992149817e1da1ba7c460d4 (patch)
treeac35b4681db887a891001c33e0f9943a0e367f83 /generate-ios-source-and-headers.py
parent853cc722a16f8d1254573ef3bb73c7b8f3d8a110 (diff)
downloadlibffi-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.py75
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)