Skip to content

Commit

Permalink
Update linker flags for MacOS
Browse files Browse the repository at this point in the history
Signed-off-by: Lucas Heitzmann Gabrielli <[email protected]>
  • Loading branch information
heitzmann committed Dec 20, 2023
1 parent 295dde7 commit 85d0805
Showing 1 changed file with 17 additions and 2 deletions.
19 changes: 17 additions & 2 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

class CMakeBuilder(build_ext):
def run(self):
darwin = platform.system() == "Darwin"
root_dir = pathlib.Path().absolute()
build_dir = pathlib.Path(self.build_temp).absolute() / "cmake_build"
install_dir = build_dir / "install"
Expand Down Expand Up @@ -50,6 +51,7 @@ def run(self):
pkgconfig = list(install_dir.glob("**/gdstk.pc"))
if len(pkgconfig) == 0:
raise RuntimeError(f"File gdstk.pc not found in cmake install tree: {install_dir}")

with open(pkgconfig[0]) as pkg:
for line in pkg:
if line.startswith("Cflags:"):
Expand All @@ -60,6 +62,11 @@ def run(self):
self.extensions[0].extra_compile_args.append(arg)
elif line.startswith("Libs:"):
for arg in line.split()[1:]:
if darwin and (arg == "-lpython" or arg.endswith("Python.framework")):
# Do not link to python in MacOS, we use the -undefined dynamic_lookup
# linker flag instead.
# See https://blog.tim-smith.us/2015/09/python-extension-modules-os-x/
continue
if arg.endswith(".framework"):
# MacOS-specific
self.extensions[0].extra_link_args.extend(
Expand All @@ -78,7 +85,7 @@ def run(self):
def loose_version(version_string):
"""Extracted from distutils.version.LooseVersion"""
version = []
for component in re.split(r'(\d+ | [a-z]+ | \.)', version_string, flags=re.VERBOSE):
for component in re.split(r"(\d+ | [a-z]+ | \.)", version_string, flags=re.VERBOSE):
if len(component) == 0 or component == ".":
continue
try:
Expand All @@ -92,7 +99,15 @@ def loose_version(version_string):
extra_link_args = []
if platform.system() == "Darwin" and loose_version(platform.release()) >= (17, 7):
extra_compile_args.extend(["-std=c++11", "-mmacosx-version-min=10.9"])
extra_link_args.extend(["-stdlib=libc++", "-mmacosx-version-min=10.9"])
extra_link_args.extend(
[
"-stdlib=libc++",
"-mmacosx-version-min=10.9",
"-undefined",
"dynamic_lookup",
"-flat_namespace",
]
)

setuptools.setup(
ext_modules=[
Expand Down

0 comments on commit 85d0805

Please sign in to comment.