如何防止 OSX gcc 总是搜索 /usr/local/include?

Posted

技术标签:

【中文标题】如何防止 OSX gcc 总是搜索 /usr/local/include?【英文标题】:How to prevent OSX gcc to always search /usr/local/include? 【发布时间】:2020-03-16 19:40:25 【问题描述】:

在我的 OSX 上,/usr/local/include 总是包含为“-I”,这让我很头疼:

hidden$ g++ -v -x c++ -isystem . -c /dev/null -o /dev/null
Apple clang version 11.0.0 (clang-1100.0.33.16)
Target: x86_64-apple-darwin19.3.0
Thread model: posix
InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin
 "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang" -cc1 -triple x86_64-apple-macosx10.15.0 -Wdeprecated-objc-isa-usage -Werror=deprecated-objc-isa-usage -emit-obj -mrelax-all -disable-free -disable-llvm-verifier -discard-value-names -main-file-name null -mrelocation-model pic -pic-level 2 -mthread-model posix -mdisable-fp-elim -fno-strict-return -masm-verbose -munwind-tables -target-sdk-version=10.15 -target-cpu penryn -dwarf-column-info -debugger-tuning=lldb -ggnu-pubnames -target-linker-version 530 -v -coverage-notes-file /dev/null.gcno -resource-dir /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/clang/11.0.0 -isystem . -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk -I/usr/local/include -stdlib=libc++ -internal-isystem /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/../include/c++/v1 -Wno-framework-include-private-from-public -Wno-atimport-in-framework-header -Wno-extra-semi-stmt -Wno-quoted-include-in-framework-header -fdeprecated-macro -fdebug-compilation-dir /tmp -ferror-limit 19 -fmessage-length 208 -stack-protector 1 -fstack-check -mdarwin-stkchk-strong-link -fblocks -fencode-extended-block-signature -fregister-global-dtors-with-atexit -fobjc-runtime=macosx-10.15.0 -fcxx-exceptions -fexceptions -fmax-type-align=16 -fdiagnostics-show-option -fcolor-diagnostics -o /dev/null -x c++ /dev/null
clang -cc1 version 11.0.0 (clang-1100.0.33.16) default target x86_64-apple-darwin19.3.0
ignoring nonexistent directory "/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include/c++/v1"
ignoring nonexistent directory "/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/local/include"
ignoring nonexistent directory "/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/Library/Frameworks"
#include "..." search starts here:
#include <...> search starts here:
 /usr/local/include
 .
 /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/../include/c++/v1
 /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/clang/11.0.0/include
 /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include
 /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include
 /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks (framework directory)
End of search list.

确切的头痛在这里并不重要,但是对于任何好奇的人来说,我的 protobuf 通过 Homebrew 安装在 /usr/local/includebazel build 使用,而我想使用我自己项目的 protobuf 版本。 Bazel 为包含路径添加了-isystem,如上图所示,被-I/usr/local/include 遮蔽。

我尝试了sudo xcode-select -s /Library/Developer/CommandLineTools,但没有帮助。

任何人都知道-I/usr/local/include 是在哪里引入的以及如何摆脱它(但不知道其他标准包含目录)?是我可以调整的一些配置,还是在编译器的二进制文件中硬编码?

【问题讨论】:

【参考方案1】:

默认情况下由 Clang 自己提供。

您可以提供-nostdinc/--no-standard-includes 来禁止此操作,但它也会禁止其他一些包含目录。

一个稍微更有针对性的方法是传递-Xclang -nostdsysteminc,但它仍然会抑制你可能想要的东西。当然,您可以在命令行上手动替换它们。

【讨论】:

这不行,通过使用-Xclang -nostdsysteminc,我只能得到/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/../include/c++/v1/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/clang/11.0.0/include,它们甚至没有像stdio.h 这样的C 头文件。 是的,就像我说的,你必须明确地添加回你想要的包含目录。您可以在问题的输出中看到您想要/需要的那些。 感谢您的信息,很高兴知道,但我不会使用这种方法,因为我的项目手动添加这些目录非常麻烦。我修改了我的问题以澄清我只想摆脱 /usr/local/include 而不是其他标准位置。此外,这个目录是在编译器的二进制文件中硬编码的,还是我可以调整的一些配置? 它是硬编码的。据我所知,除了破解代码和自己构建编译器之外,没有其他方法可以避免添加它。

以上是关于如何防止 OSX gcc 总是搜索 /usr/local/include?的主要内容,如果未能解决你的问题,请参考以下文章

Mac OSX 上的 GCC——多个版本的 gcc

Qt 5.1 for OSX 安装只包含 clang_64 目录,如何使用 macports gcc 编译?

如何防止 html5 视频在 OSX 上休眠

如何在 Mac OSX 下使用 gcc 设置可执行文件的运行时路径(-rpath)?

如何防止大字体在Chrome(OSX)中看起来锯齿状?

CUDA 与我的 gcc 版本不兼容