将 -rpath 和 $ORIGIN 用于基于 libtool 的项目
Using -rpath and $ORIGIN with libtool-based projects?
我正在尝试将基于 libtool 的包合并到我自己的项目中,也许是以非标准的方式。 这是我的目标:
-
构建外部项目:
./configure --prefix=$HOME/blah --etcetera && make && make install
-
在运行时构建我自己的项目,该项目依赖于外部项目的共享库和可执行文件:
gcc -I$HOME/blah/include -L$HOME/blah/lib -o $HOME/blah/bin/program
-
将所有内容打包到一个"本地化"的压缩包中......也就是说,虽然我在构建主机上
$HOME/blah
了所有内容,但我希望能够将压缩包提取到任何任意目录(在其他主机上(,而不必在我的环境中摸索。 目的是允许我的项目的多个版本并排共存,而没有任何令人讨厌的"异花授粉"。
我知道我可以在我的项目中使用 -rpath '$ORIGIN/../lib'
来确保始终在运行时加载正确的共享库。 但是,libtool 似乎坚持根据 $HOME/blah/lib
的确切路径分配自己的-rpath
设置,如果我碰巧将所有内容解压缩到不同的目录(例如,$HOME/blah.2011-06-02
(,则会中断。
有没有办法绕过这个限制? 我看到 debian 和 libtool 人员之间关于这个话题的相当冗长的 rpath 讨论,但它除了"我们不同意"之外有些陈旧且不确定。
在 debian Wiki 上的 Rpathissue 上提供的选项中,在"安装"步骤中使用chrpath
或一些后处理脚本听起来像是一个可行的选择。(它可以通过您最喜欢的包管理器在一堆发行版上使用。
它不需要修补libtool
这是一个加号IMO。
请注意,它有一些限制:仅当新rpath
与原始更短(或长度相同(时,才能保存新。
另一个(务实的(选项是删除rpath
(chrpath可以做到这一点(,并且只需使用一个包装脚本,将LD_LIBRARY_PATH
设置为应用程序所需的任何内容。这也有可能稍微更具可移植性(如果您处理某些操作系统具有的其他共享库路径环境变量(。
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 无法在 CLion 中构建 C++ 项目
- 运行同一解决方案的另一个项目的项目
- CMake-按正确顺序将项目与C运行时对象文件链接
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 欧拉项目#8答案是大以获得有效答案
- 从链接列表c++中删除一个项目
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- 既然存在危险,为什么项目要使用-I include开关
- cmake在我的项目中所需的所有静态库都不成功
- QT通过C++添加映射QML项目
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- 在linux上调试巨大的C++项目
- 在其他文件中创建类时在 c++ 项目中不起作用
- 使外部项目可用于find_package CMake
- 在子目录中使用target_sources()命令时用于单元测试(qtest)的项目结构
- 使用外部SDK工具链文件在VisualStudio上生成项目编译错误
- 如何维护资源管理器项目视图中当前可见的项目列表
- 错误-我无法在VS2019中打开新的Qt项目
- 将 -rpath 和 $ORIGIN 用于基于 libtool 的项目