Skip to content

Commit 9d23c15

Browse files
committed
Further tweaking of PG_SYSROOT heuristics for macOS.
It emerges that in some phases of the moon (perhaps to do with directory entry order?), xcrun will report that the SDK path is /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk which is normally a symlink to a version-numbered sibling directory. Our heuristic to skip non-version-numbered pathnames was rejecting that, which is the wrong thing to do. We'd still like to end up with a version-numbered PG_SYSROOT value, but we can have that by dereferencing the symlink. Like the previous fix, back-patch to all supported versions. Discussion: https://postgr.es/m/522433.1611089678@sss.pgh.pa.us
1 parent c2dc1a7 commit 9d23c15

File tree

1 file changed

+13
-6
lines changed

1 file changed

+13
-6
lines changed

src/template/darwin

Lines changed: 13 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -7,13 +7,20 @@
77
if test x"$PG_SYSROOT" = x"" ; then
88
# This is far more complicated than it ought to be. We first ask
99
# "xcrun --show-sdk-path", which seems to match the default -isysroot
10-
# setting of Apple's compilers. However, that may produce no result or
11-
# a result that is not version-specific (i.e., just ".../SDKs/MacOSX.sdk").
12-
# Using a version-specific sysroot seems desirable, so if there are not
13-
# digits in the directory name, try "xcrun --sdk macosx --show-sdk-path";
14-
# and if that still doesn't work, fall back to asking xcodebuild,
15-
# which is often a good deal slower.
10+
# setting of Apple's compilers.
1611
PG_SYSROOT=`xcrun --show-sdk-path 2>/dev/null`
12+
# That may fail, or produce a result that is not version-specific (i.e.,
13+
# just ".../SDKs/MacOSX.sdk"). Using a version-specific sysroot seems
14+
# desirable, so if the path is a non-version-specific symlink, expand it.
15+
if test -L "$PG_SYSROOT"; then
16+
if expr x"$PG_SYSROOT" : '.*[0-9]\.[0-9][^/]*$' >/dev/null ; then : okay
17+
else
18+
PG_SYSROOT=`expr "$PG_SYSROOT" : '\(.*\)/'`/`readlink "$PG_SYSROOT"`
19+
fi
20+
fi
21+
# If there are still not digits in the directory name, try
22+
# "xcrun --sdk macosx --show-sdk-path"; and if that still doesn't work,
23+
# fall back to asking xcodebuild, which is often a good deal slower.
1724
if expr x"$PG_SYSROOT" : '.*[0-9]\.[0-9][^/]*$' >/dev/null ; then : okay
1825
else
1926
PG_SYSROOT=`xcrun --sdk macosx --show-sdk-path 2>/dev/null`

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy