自莫哈韦以来,链接在自制软件的 cmake 中不起作用

Linking not working in homebrew's cmake since Mojave

本文关键字:软件 cmake 不起作用 链接 哈韦      更新时间:2023-10-16

我现在已经在两台计算机上重现了这种症状,自从我的机器升级到macOS Mojave后,cmake似乎不再在/usr/local/lib(或者更准确地说,$(brew --prefix)/lib)中查找Homebrew提供的库。

尽管有一些方法可以避免这种情况(例如,使用EXECUTE_PROCESS搜索自制前缀;将结果添加到LINK_LIBRARIES(...)命令中),但没有一种是理想的。莫哈韦发生了什么变化来打破这种行为?

临时解决方法是在CMakeLists.txt中添加以下内容:

# WARNING: Don't hard-code this path
LINK_DIRECTORIES(/usr/local/lib)

我已经尝试过brew doctor,并更新了所有自制软件包,但都没有成功。

cmake(make)显示的具体错误为:

ld: library not found for -l<somelib>

我在Homebrew论坛和苹果开发者论坛上问过这个问题。

在OS X Mojave(10.14)下的Django应用程序中尝试pip install psycopg2时遇到相关(?)问题。我收到以下错误:

ld: library not found for -lssl
clang: error: linker command failed with exit code 1 (use -v to see invocation)
error: command 'clang' failed with exit status 1

简短的解释:«从High Sierra开始,/usr/local不再是chown able。。。»

解决方案:更改/usr/local的权限以允许Homebrew创建链接。

我根据自己的需要调整了解决方案。然后我终于可以运行pip install psycopg2了。以下是命令序列(update:在您的项目根目录中,即您看到manage.py的位置)。

第一个

sudo chown -R $(whoami) $(brew --prefix)/*

然后

brew reinstall openssl
export LDFLAGS="-L/usr/local/opt/openssl/lib"
export CPPFLAGS="-I/usr/local/opt/openssl/include"
pip install psycopg2

我已经将其与VERBOSE=1 make日志中的以下更改隔离开来。。。

  • High Sierra(<=10.13)及以下版本使用了NOT-isysroot命令
  • 莫哈韦(>=10.14)确实使用-isysroot命令

来自gnu.org:

-isysroot <dir>此选项类似于--sysroot选项,但仅适用于头文件(除了Darwin目标,它同时适用于头和库)。有关详细信息,请参阅--sysroot选项。

因此,此标志仅在Apple上专门破坏lib搜索路径。这导致编译从不查找标准ld位置,这可以通过键入ld -v dummy来查看。

Library search paths:
/usr/lib
/usr/local/lib

cmake为什么要这样做?我的想法是修复新的Mojave SDK行为引入的/usr/local/include问题。

不幸的是,我找不到cmake编译标志来添加默认的库搜索路径。目前,我找到的唯一解决方案是将以下内容添加到我的项目中:

IF(APPLE)
# Fix linking on 10.14+. See https://stackoverflow.com/questions/54068035
LINK_DIRECTORIES(/usr/local/lib)
ENDIF()

我不确定这是否是一种需要上游cmake补丁的行为。如果有更好的解决方案,请提供。