@@ -19,7 +19,6 @@ clang_prog=$(build_prefix)/bin/clang
19
19
clangxx_prog =$(clang_prog ) ++
20
20
llvm_config_prog =$(build_prefix ) /bin/llvm-config
21
21
22
- clang_resource_dir =$(build_prefix ) /lib/clang/$(native_clang_version )
23
22
else
24
23
# FORCE_USE_SYSTEM_CLANG is non-empty, so we use the clang from the user's
25
24
# system
@@ -37,7 +36,6 @@ clang_prog=$(shell $(SHELL) $(.SHELLFLAGS) "command -v clang")
37
36
clangxx_prog =$(shell $(SHELL ) $(.SHELLFLAGS ) "command -v clang++")
38
37
llvm_config_prog =$(shell $(SHELL ) $(.SHELLFLAGS ) "command -v llvm-config")
39
38
40
- clang_resource_dir =$(shell clang -print-resource-dir)
41
39
llvm_lib_dir =$(shell $(llvm_config_prog ) --libdir)
42
40
endif
43
41
@@ -63,53 +61,33 @@ $(foreach TOOL,$(cctools_TOOLS),$(eval darwin_$(TOOL) = $$(build_prefix)/bin/$$(
63
61
# Explicitly point to our binaries (e.g. cctools) so that they are
64
62
# ensured to be found and preferred over other possibilities.
65
63
#
66
- # -stdlib++-isystem $(OSX_SDK)/usr/include/c++/v1
64
+ # -isysroot $(OSX_SDK) -nostdlibinc
67
65
#
68
- # Forces clang to use the libc++ headers from our SDK and completely
69
- # forget about the libc++ headers from the standard directories
66
+ # Disable default include paths built into the compiler as well as
67
+ # those normally included for libc and libc++. The only path that
68
+ # remains implicitly is the clang resource dir.
70
69
#
71
- # -Xclang -*system<path_a> \
72
- # -Xclang -*system<path_b> \
73
- # -Xclang -*system<path_c> ...
70
+ # -iwithsysroot / -iframeworkwithsysroot
74
71
#
75
- # Adds path_a, path_b, and path_c to the bottom of clang's list of
76
- # include search paths. This is used to explicitly specify the list of
77
- # system include search paths and its ordering, rather than rely on
78
- # clang's autodetection routine. This routine has been shown to:
79
- # 1. Fail to pickup libc++ headers in $SYSROOT/usr/include/c++/v1
80
- # when clang was built manually (see: https://github.com/bitcoin/bitcoin/pull/17919#issuecomment-656785034)
81
- # 2. Fail to pickup C headers in $SYSROOT/usr/include when
82
- # C_INCLUDE_DIRS was specified at configure time (see: https://gist.github.com/dongcarl/5cdc6990b7599e8a5bf6d2a9c70e82f9)
83
- #
84
- # Talking directly to cc1 with -Xclang here grants us access to specify
85
- # more granular categories for these system include search paths, and we
86
- # can use the correct categories that these search paths would have been
87
- # placed in if the autodetection routine had worked correctly. (see:
88
- # https://gist.github.com/dongcarl/5cdc6990b7599e8a5bf6d2a9c70e82f9#the-treatment)
89
- #
90
- # Furthermore, it places these search paths after any "non-Xclang"
91
- # specified search paths. This prevents any additional clang options or
92
- # environment variables from coming after or in between these system
93
- # include search paths, as that would be wrong in general but would also
94
- # break #include_next's.
72
+ # Adds the desired paths from the SDK
95
73
#
74
+
96
75
darwin_CC =env -u C_INCLUDE_PATH -u CPLUS_INCLUDE_PATH \
97
76
-u OBJC_INCLUDE_PATH -u OBJCPLUS_INCLUDE_PATH -u CPATH \
98
77
-u LIBRARY_PATH \
99
78
$(clang_prog ) --target=$(host ) -mmacosx-version-min=$(OSX_MIN_VERSION ) \
100
79
-B$(build_prefix ) /bin -mlinker-version=$(LD64_VERSION ) \
101
- -isysroot$(OSX_SDK ) \
102
- -Xclang -internal-externc-isystem -Xclang $( clang_resource_dir ) / include \
103
- -Xclang -internal-externc-isystem -Xclang $( OSX_SDK ) /usr/include
80
+ -isysroot$(OSX_SDK ) -nostdlibinc \
81
+ -iwithsysroot/usr/ include -iframeworkwithsysroot/System/Library/Frameworks
82
+
104
83
darwin_CXX =env -u C_INCLUDE_PATH -u CPLUS_INCLUDE_PATH \
105
84
-u OBJC_INCLUDE_PATH -u OBJCPLUS_INCLUDE_PATH -u CPATH \
106
85
-u LIBRARY_PATH \
107
86
$(clangxx_prog ) --target=$(host ) -mmacosx-version-min=$(OSX_MIN_VERSION ) \
108
87
-B$(build_prefix ) /bin -mlinker-version=$(LD64_VERSION ) \
109
- -isysroot$(OSX_SDK ) \
110
- -stdlib++-isystem$(OSX_SDK ) /usr/include/c++/v1 \
111
- -Xclang -internal-externc-isystem -Xclang $(clang_resource_dir ) /include \
112
- -Xclang -internal-externc-isystem -Xclang $(OSX_SDK ) /usr/include
88
+ -isysroot$(OSX_SDK ) -nostdlibinc \
89
+ -iwithsysroot/usr/include/c++/v1 \
90
+ -iwithsysroot/usr/include -iframeworkwithsysroot/System/Library/Frameworks
113
91
114
92
darwin_CFLAGS =-pipe -std=$(C_STANDARD )
115
93
darwin_CXXFLAGS =-pipe -std=$(CXX_STANDARD )
0 commit comments