wip macos
motiejus@mtwork:/code/bazel-zig-cc$ bazel build --spawn_strategy=local --platforms @zig_sdk//libc_aware/platform:macos_aarch64_sdk.13.1 test/c:which_libc
INFO: Analyzed target //test/c:which_libc (0 packages loaded, 0 targets configured).
INFO: Found 1 target...
Target //test/c:which_libc up-to-date:
bazel-bin/test/c/which_libc
INFO: Elapsed time: 0.071s, Critical Path: 0.00s
INFO: 1 process: 1 internal.
INFO: Build completed successfully, 1 total action
motiejus@mtwork:/code/bazel-zig-cc$ file bazel-bin/test/c/which_libc
bazel-bin/test/c/which_libc: Mach-O 64-bit arm64 executable, flags:<NOUNDEFS|DYLDLINK|TWOLEVEL|PIE>
motiejus@mtwork:/code/bazel-zig-cc$
This commit is contained in:
@@ -11,12 +11,11 @@ DEFAULT_TOOL_PATHS = {
|
||||
"strip": "/usr/bin/false",
|
||||
}.items()
|
||||
|
||||
def declare_cc_toolchains(os, zig_sdk_path):
|
||||
for target_config in target_structs():
|
||||
def declare_cc_toolchains(os, zig_sdk_path, macos_sdk_versions):
|
||||
for target_config in target_structs(macos_sdk_versions):
|
||||
gotarget = target_config.gotarget
|
||||
zigtarget = target_config.zigtarget
|
||||
|
||||
cxx_builtin_include_directories = []
|
||||
absolute_tool_paths = {}
|
||||
for name, path in target_config.tool_paths.items() + DEFAULT_TOOL_PATHS:
|
||||
if path[0] == "/":
|
||||
@@ -30,9 +29,9 @@ def declare_cc_toolchains(os, zig_sdk_path):
|
||||
|
||||
dynamic_library_linkopts = target_config.dynamic_library_linkopts
|
||||
copts = target_config.copts
|
||||
linkopts = []
|
||||
linkopts = target_config.linkopts
|
||||
for s in getattr(target_config, "linker_version_scripts", []):
|
||||
linkopts = ["-Wl,--version-script,%s/%s" % (zig_sdk_path, s)]
|
||||
linkopts.append("-Wl,--version-script,%s/%s" % (zig_sdk_path, s))
|
||||
for incl in getattr(target_config, "compiler_extra_includes", []):
|
||||
copts = copts + ["-include", zig_sdk_path + "/" + incl]
|
||||
|
||||
@@ -44,7 +43,11 @@ def declare_cc_toolchains(os, zig_sdk_path):
|
||||
name = zigtarget + "_cc_config",
|
||||
target = zigtarget,
|
||||
tool_paths = absolute_tool_paths,
|
||||
cxx_builtin_include_directories = cxx_builtin_include_directories,
|
||||
cxx_builtin_include_directories = getattr(
|
||||
target_config,
|
||||
"cxx_builtin_include_directories",
|
||||
[],
|
||||
),
|
||||
copts = copts,
|
||||
linkopts = linkopts,
|
||||
dynamic_library_linkopts = dynamic_library_linkopts,
|
||||
|
||||
@@ -36,36 +36,41 @@ def zig_tool_path(os):
|
||||
else:
|
||||
return _ZIG_TOOL_PATH
|
||||
|
||||
def target_structs():
|
||||
def target_structs(macos_sdk_versions):
|
||||
ret = []
|
||||
for zigcpu, gocpu in (("x86_64", "amd64"), ("aarch64", "arm64")):
|
||||
ret.append(_target_macos(gocpu, zigcpu))
|
||||
ret.append(_target_windows(gocpu, zigcpu))
|
||||
ret.append(_target_linux_musl(gocpu, zigcpu))
|
||||
for glibc in _GLIBCS:
|
||||
ret.append(_target_linux_gnu(gocpu, zigcpu, glibc))
|
||||
for macos_sdk_version in macos_sdk_versions:
|
||||
ret.append(_target_macos(gocpu, zigcpu, macos_sdk_version))
|
||||
return ret
|
||||
|
||||
def _target_macos(gocpu, zigcpu):
|
||||
min_os = "11"
|
||||
copts = []
|
||||
def _target_macos(gocpu, zigcpu, macos_sdk_version):
|
||||
macos_sdk_opts = [
|
||||
"--sysroot",
|
||||
"external/macos_sdk_{}".format(macos_sdk_version),
|
||||
"-F",
|
||||
"/System/Library/Frameworks",
|
||||
]
|
||||
|
||||
copts = macos_sdk_opts
|
||||
|
||||
if zigcpu == "aarch64":
|
||||
copts = ["-mcpu=apple_m1"]
|
||||
copts.append("-mcpu=apple_m1")
|
||||
|
||||
return struct(
|
||||
gotarget = "darwin_{}".format(gocpu),
|
||||
zigtarget = "{}-macos-none".format(zigcpu),
|
||||
includes = [
|
||||
"libunwind/include",
|
||||
# TODO: Define a toolchain for each minimum OS version
|
||||
"libc/include/{}-macos.{}-none".format(zigcpu, min_os),
|
||||
"libc/include/any-macos.{}-any".format(min_os),
|
||||
"libc/include/any-macos-any",
|
||||
] + _INCLUDE_TAIL,
|
||||
gotarget = "darwin_{}_sdk.{}".format(gocpu, macos_sdk_version),
|
||||
zigtarget = "{}-macos-sdk.{}".format(zigcpu, macos_sdk_version),
|
||||
includes = [],
|
||||
linkopts = macos_sdk_opts,
|
||||
dynamic_library_linkopts = ["-Wl,-undefined=dynamic_lookup"],
|
||||
cxx_builtin_include_directories = ["external/macos_sdk_{}/usr/include".format(macos_sdk_version)],
|
||||
sdk_include_files = ["@macos_sdk_{}//:usr_include".format(macos_sdk_version)],
|
||||
sdk_lib_files = ["@macos_sdk_{}//:usr_lib".format(macos_sdk_version)],
|
||||
copts = copts,
|
||||
libc = "darwin",
|
||||
libc = "macos",
|
||||
bazel_target_cpu = "darwin",
|
||||
constraint_values = [
|
||||
"@platforms//os:macos",
|
||||
@@ -79,6 +84,7 @@ def _target_macos(gocpu, zigcpu):
|
||||
"extension": ".dylib",
|
||||
},
|
||||
],
|
||||
libc_constraint = "@zig_sdk//libc:macos.{}".format(macos_sdk_version),
|
||||
)
|
||||
|
||||
def _target_windows(gocpu, zigcpu):
|
||||
@@ -90,6 +96,7 @@ def _target_windows(gocpu, zigcpu):
|
||||
"libunwind/include",
|
||||
"libc/include/any-windows-any",
|
||||
] + _INCLUDE_TAIL,
|
||||
linkopts = [],
|
||||
dynamic_library_linkopts = [],
|
||||
copts = [],
|
||||
libc = "mingw",
|
||||
@@ -145,6 +152,7 @@ def _target_linux_gnu(gocpu, zigcpu, glibc_version):
|
||||
] + _INCLUDE_TAIL,
|
||||
compiler_extra_includes = compiler_extra_includes,
|
||||
linker_version_scripts = linker_version_scripts,
|
||||
linkopts = [],
|
||||
dynamic_library_linkopts = [],
|
||||
copts = [],
|
||||
libc = "glibc",
|
||||
@@ -171,6 +179,7 @@ def _target_linux_musl(gocpu, zigcpu):
|
||||
(["libc/include/{}-linux-any".format(zigcpu)] if zigcpu != "x86_64" else []) + [
|
||||
"libc/include/any-linux-any",
|
||||
] + _INCLUDE_TAIL,
|
||||
linkopts = [],
|
||||
dynamic_library_linkopts = [],
|
||||
copts = ["-D_LIBCPP_HAS_MUSL_LIBC", "-D_LIBCPP_HAS_THREAD_API_PTHREAD"],
|
||||
libc = "musl",
|
||||
|
||||
Reference in New Issue
Block a user