|
@@ -34,6 +34,7 @@ def get_opts():
|
|
|
" validation layers)",
|
|
|
False,
|
|
|
),
|
|
|
+ BoolVariable("ios_simulator", "Build for iOS Simulator", False),
|
|
|
BoolVariable("ios_exceptions", "Enable exceptions", False),
|
|
|
("ios_triple", "Triple for ios toolchain", ""),
|
|
|
]
|
|
@@ -107,8 +108,17 @@ def configure(env):
|
|
|
|
|
|
## Compile flags
|
|
|
|
|
|
- if env["arch"] == "x86" or env["arch"] == "x86_64":
|
|
|
+ if env["ios_simulator"]:
|
|
|
detect_darwin_sdk_path("iphonesimulator", env)
|
|
|
+ env.Append(CCFLAGS=["-mios-simulator-version-min=13.0"])
|
|
|
+ env.Append(LINKFLAGS=["-mios-simulator-version-min=13.0"])
|
|
|
+ env.extra_suffix = ".simulator" + env.extra_suffix
|
|
|
+ else:
|
|
|
+ detect_darwin_sdk_path("iphone", env)
|
|
|
+ env.Append(CCFLAGS=["-miphoneos-version-min=11.0"])
|
|
|
+ env.Append(LINKFLAGS=["-miphoneos-version-min=11.0"])
|
|
|
+
|
|
|
+ if env["arch"] == "x86" or env["arch"] == "x86_64":
|
|
|
env["ENV"]["MACOSX_DEPLOYMENT_TARGET"] = "10.9"
|
|
|
arch_flag = "i386" if env["arch"] == "x86" else env["arch"]
|
|
|
env.Append(
|
|
@@ -116,11 +126,10 @@ def configure(env):
|
|
|
"-fobjc-arc -arch "
|
|
|
+ arch_flag
|
|
|
+ " -fobjc-abi-version=2 -fobjc-legacy-dispatch -fmessage-length=0 -fpascal-strings -fblocks"
|
|
|
- " -fasm-blocks -isysroot $IPHONESDK -mios-simulator-version-min=13.0"
|
|
|
+ " -fasm-blocks -isysroot $IPHONESDK"
|
|
|
).split()
|
|
|
)
|
|
|
elif env["arch"] == "arm":
|
|
|
- detect_darwin_sdk_path("iphone", env)
|
|
|
env.Append(
|
|
|
CCFLAGS=(
|
|
|
"-fobjc-arc -arch armv7 -fmessage-length=0 -fno-strict-aliasing"
|
|
@@ -128,16 +137,15 @@ def configure(env):
|
|
|
" -fpascal-strings -fblocks -isysroot $IPHONESDK -fvisibility=hidden -mthumb"
|
|
|
' "-DIBOutlet=__attribute__((iboutlet))"'
|
|
|
' "-DIBOutletCollection(ClassName)=__attribute__((iboutletcollection(ClassName)))"'
|
|
|
- ' "-DIBAction=void)__attribute__((ibaction)" -miphoneos-version-min=11.0 -MMD -MT dependencies'.split()
|
|
|
+ ' "-DIBAction=void)__attribute__((ibaction)" -MMD -MT dependencies'.split()
|
|
|
)
|
|
|
)
|
|
|
elif env["arch"] == "arm64":
|
|
|
- detect_darwin_sdk_path("iphone", env)
|
|
|
env.Append(
|
|
|
CCFLAGS=(
|
|
|
"-fobjc-arc -arch arm64 -fmessage-length=0 -fno-strict-aliasing"
|
|
|
" -fdiagnostics-print-source-range-info -fdiagnostics-show-category=id -fdiagnostics-parseable-fixits"
|
|
|
- " -fpascal-strings -fblocks -fvisibility=hidden -MMD -MT dependencies -miphoneos-version-min=11.0"
|
|
|
+ " -fpascal-strings -fblocks -fvisibility=hidden -MMD -MT dependencies"
|
|
|
" -isysroot $IPHONESDK".split()
|
|
|
)
|
|
|
)
|
|
@@ -162,7 +170,6 @@ def configure(env):
|
|
|
LINKFLAGS=[
|
|
|
"-arch",
|
|
|
arch_flag,
|
|
|
- "-mios-simulator-version-min=13.0",
|
|
|
"-isysroot",
|
|
|
"$IPHONESDK",
|
|
|
"-Xlinker",
|
|
@@ -173,9 +180,9 @@ def configure(env):
|
|
|
]
|
|
|
)
|
|
|
elif env["arch"] == "arm":
|
|
|
- env.Append(LINKFLAGS=["-arch", "armv7", "-Wl,-dead_strip", "-miphoneos-version-min=11.0"])
|
|
|
+ env.Append(LINKFLAGS=["-arch", "armv7", "-Wl,-dead_strip"])
|
|
|
if env["arch"] == "arm64":
|
|
|
- env.Append(LINKFLAGS=["-arch", "arm64", "-Wl,-dead_strip", "-miphoneos-version-min=11.0"])
|
|
|
+ env.Append(LINKFLAGS=["-arch", "arm64", "-Wl,-dead_strip"])
|
|
|
|
|
|
env.Append(
|
|
|
LINKFLAGS=[
|