Merge pull request #1191 from Faless/build/unify_osxcross
[SCons] Merge OSXCross tools into platform onespull/1203/head
commit
845226d66a
35
tools/ios.py
35
tools/ios.py
|
@ -1,7 +1,6 @@
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import subprocess
|
import subprocess
|
||||||
import ios_osxcross
|
|
||||||
from SCons.Variables import *
|
from SCons.Variables import *
|
||||||
|
|
||||||
if sys.version_info < (3,):
|
if sys.version_info < (3,):
|
||||||
|
@ -16,6 +15,10 @@ else:
|
||||||
return codecs.utf_8_decode(x)[0]
|
return codecs.utf_8_decode(x)[0]
|
||||||
|
|
||||||
|
|
||||||
|
def has_ios_osxcross():
|
||||||
|
return "OSXCROSS_IOS" in os.environ
|
||||||
|
|
||||||
|
|
||||||
def options(opts):
|
def options(opts):
|
||||||
opts.Add(BoolVariable("ios_simulator", "Target iOS Simulator", False))
|
opts.Add(BoolVariable("ios_simulator", "Target iOS Simulator", False))
|
||||||
opts.Add("ios_min_version", "Target minimum iphoneos/iphonesimulator version", "10.0")
|
opts.Add("ios_min_version", "Target minimum iphoneos/iphonesimulator version", "10.0")
|
||||||
|
@ -25,17 +28,18 @@ def options(opts):
|
||||||
"/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain",
|
"/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain",
|
||||||
)
|
)
|
||||||
opts.Add("IOS_SDK_PATH", "Path to the iOS SDK", "")
|
opts.Add("IOS_SDK_PATH", "Path to the iOS SDK", "")
|
||||||
ios_osxcross.options(opts)
|
|
||||||
|
if has_ios_osxcross():
|
||||||
|
opts.Add("ios_triple", "Triple for ios toolchain", "")
|
||||||
|
|
||||||
|
|
||||||
def exists(env):
|
def exists(env):
|
||||||
return sys.platform == "darwin" or ios_osxcross.exists(env)
|
return sys.platform == "darwin" or has_ios_osxcross()
|
||||||
|
|
||||||
|
|
||||||
def generate(env):
|
def generate(env):
|
||||||
if env["arch"] not in ("universal", "arm64", "x86_64"):
|
if env["arch"] not in ("universal", "arm64", "x86_64"):
|
||||||
print("Only universal, arm64, and x86_64 are supported on iOS. Exiting.")
|
raise ValueError("Only universal, arm64, and x86_64 are supported on iOS. Exiting.")
|
||||||
Exit()
|
|
||||||
|
|
||||||
if env["ios_simulator"]:
|
if env["ios_simulator"]:
|
||||||
sdk_name = "iphonesimulator"
|
sdk_name = "iphonesimulator"
|
||||||
|
@ -64,7 +68,26 @@ def generate(env):
|
||||||
env["ENV"]["PATH"] = env["IOS_TOOLCHAIN_PATH"] + "/Developer/usr/bin/:" + env["ENV"]["PATH"]
|
env["ENV"]["PATH"] = env["IOS_TOOLCHAIN_PATH"] + "/Developer/usr/bin/:" + env["ENV"]["PATH"]
|
||||||
|
|
||||||
else:
|
else:
|
||||||
ios_osxcross.generate(env)
|
# OSXCross
|
||||||
|
compiler_path = "$IOS_TOOLCHAIN_PATH/usr/bin/${ios_triple}"
|
||||||
|
env["CC"] = compiler_path + "clang"
|
||||||
|
env["CXX"] = compiler_path + "clang++"
|
||||||
|
env["AR"] = compiler_path + "ar"
|
||||||
|
env["RANLIB"] = compiler_path + "ranlib"
|
||||||
|
env["SHLIBSUFFIX"] = ".dylib"
|
||||||
|
|
||||||
|
env.Prepend(
|
||||||
|
CPPPATH=[
|
||||||
|
"$IOS_SDK_PATH/usr/include",
|
||||||
|
"$IOS_SDK_PATH/System/Library/Frameworks/AudioUnit.framework/Headers",
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
env.Append(CCFLAGS=["-stdlib=libc++"])
|
||||||
|
|
||||||
|
binpath = os.path.join(env["IOS_TOOLCHAIN_PATH"], "usr", "bin")
|
||||||
|
if binpath not in env["ENV"]["PATH"]:
|
||||||
|
env.PrependENVPath("PATH", binpath)
|
||||||
|
|
||||||
if env["arch"] == "universal":
|
if env["arch"] == "universal":
|
||||||
if env["ios_simulator"]:
|
if env["ios_simulator"]:
|
||||||
|
|
|
@ -1,26 +0,0 @@
|
||||||
import os
|
|
||||||
|
|
||||||
|
|
||||||
def options(opts):
|
|
||||||
opts.Add("ios_triple", "Triple for ios toolchain", "")
|
|
||||||
|
|
||||||
|
|
||||||
def exists(env):
|
|
||||||
return "OSXCROSS_IOS" in os.environ
|
|
||||||
|
|
||||||
|
|
||||||
def generate(env):
|
|
||||||
compiler_path = "$IOS_TOOLCHAIN_PATH/usr/bin/${ios_triple}"
|
|
||||||
env["CC"] = compiler_path + "clang"
|
|
||||||
env["CXX"] = compiler_path + "clang++"
|
|
||||||
env["AR"] = compiler_path + "ar"
|
|
||||||
env["RANLIB"] = compiler_path + "ranlib"
|
|
||||||
env["SHLIBSUFFIX"] = ".dylib"
|
|
||||||
|
|
||||||
env.Prepend(
|
|
||||||
CPPPATH=[
|
|
||||||
"$IOS_SDK_PATH/usr/include",
|
|
||||||
"$IOS_SDK_PATH/System/Library/Frameworks/AudioUnit.framework/Headers",
|
|
||||||
]
|
|
||||||
)
|
|
||||||
env.Append(CCFLAGS=["-stdlib=libc++"])
|
|
|
@ -1,16 +1,20 @@
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import macos_osxcross
|
|
||||||
|
|
||||||
|
def has_osxcross():
|
||||||
|
return "OSXCROSS_ROOT" in os.environ
|
||||||
|
|
||||||
|
|
||||||
def options(opts):
|
def options(opts):
|
||||||
opts.Add("macos_deployment_target", "macOS deployment target", "default")
|
opts.Add("macos_deployment_target", "macOS deployment target", "default")
|
||||||
opts.Add("macos_sdk_path", "macOS SDK path", "")
|
opts.Add("macos_sdk_path", "macOS SDK path", "")
|
||||||
macos_osxcross.options(opts)
|
if has_osxcross():
|
||||||
|
opts.Add("osxcross_sdk", "OSXCross SDK version", "darwin16")
|
||||||
|
|
||||||
|
|
||||||
def exists(env):
|
def exists(env):
|
||||||
return sys.platform == "darwin" or macos_osxcross.exists(env)
|
return sys.platform == "darwin" or has_osxcross()
|
||||||
|
|
||||||
|
|
||||||
def generate(env):
|
def generate(env):
|
||||||
|
@ -23,9 +27,25 @@ def generate(env):
|
||||||
env["CXX"] = "clang++"
|
env["CXX"] = "clang++"
|
||||||
env["CC"] = "clang"
|
env["CC"] = "clang"
|
||||||
else:
|
else:
|
||||||
# Use osxcross
|
# OSXCross
|
||||||
macos_osxcross.generate(env)
|
root = os.environ.get("OSXCROSS_ROOT", "")
|
||||||
|
if env["arch"] == "arm64":
|
||||||
|
basecmd = root + "/target/bin/arm64-apple-" + env["osxcross_sdk"] + "-"
|
||||||
|
else:
|
||||||
|
basecmd = root + "/target/bin/x86_64-apple-" + env["osxcross_sdk"] + "-"
|
||||||
|
|
||||||
|
env["CC"] = basecmd + "clang"
|
||||||
|
env["CXX"] = basecmd + "clang++"
|
||||||
|
env["AR"] = basecmd + "ar"
|
||||||
|
env["RANLIB"] = basecmd + "ranlib"
|
||||||
|
env["AS"] = basecmd + "as"
|
||||||
|
|
||||||
|
binpath = os.path.join(root, "target", "bin")
|
||||||
|
if binpath not in env["ENV"]["PATH"]:
|
||||||
|
# Add OSXCROSS bin folder to PATH (required for linking).
|
||||||
|
env.PrependENVPath("PATH", binpath)
|
||||||
|
|
||||||
|
# Common flags
|
||||||
if env["arch"] == "universal":
|
if env["arch"] == "universal":
|
||||||
env.Append(LINKFLAGS=["-arch", "x86_64", "-arch", "arm64"])
|
env.Append(LINKFLAGS=["-arch", "x86_64", "-arch", "arm64"])
|
||||||
env.Append(CCFLAGS=["-arch", "x86_64", "-arch", "arm64"])
|
env.Append(CCFLAGS=["-arch", "x86_64", "-arch", "arm64"])
|
||||||
|
|
|
@ -1,28 +0,0 @@
|
||||||
import os
|
|
||||||
|
|
||||||
|
|
||||||
def options(opts):
|
|
||||||
opts.Add("osxcross_sdk", "OSXCross SDK version", "darwin16")
|
|
||||||
|
|
||||||
|
|
||||||
def exists(env):
|
|
||||||
return "OSXCROSS_ROOT" in os.environ
|
|
||||||
|
|
||||||
|
|
||||||
def generate(env):
|
|
||||||
root = os.environ.get("OSXCROSS_ROOT", "")
|
|
||||||
if env["arch"] == "arm64":
|
|
||||||
basecmd = root + "/target/bin/arm64-apple-" + env["osxcross_sdk"] + "-"
|
|
||||||
else:
|
|
||||||
basecmd = root + "/target/bin/x86_64-apple-" + env["osxcross_sdk"] + "-"
|
|
||||||
|
|
||||||
env["CC"] = basecmd + "clang"
|
|
||||||
env["CXX"] = basecmd + "clang++"
|
|
||||||
env["AR"] = basecmd + "ar"
|
|
||||||
env["RANLIB"] = basecmd + "ranlib"
|
|
||||||
env["AS"] = basecmd + "as"
|
|
||||||
|
|
||||||
binpath = os.path.join(root, "target", "bin")
|
|
||||||
if binpath not in env["ENV"]["PATH"]:
|
|
||||||
# Add OSXCROSS bin folder to PATH (required for linking).
|
|
||||||
env["ENV"]["PATH"] = "%s:%s" % (binpath, env["ENV"]["PATH"])
|
|
Loading…
Reference in New Issue