c – 如何构建一个没有硬编码的完全依赖路径的共享库(.so)?

我需要建立两个第三方共享库,所以他们的.so文件将被其他项目重用.但是,构建这些库之后,包含硬编码的路径到另一个.此路径在其他机器上无效,并导致链接器警告.如何阻止完整路径嵌入到生成.so文件中?

细节:

一个库源码:〜/ dev / A
第二库源:〜/ dev / B

他们都配置脚本来生成make文件.图书馆B依赖于A.所以,首先我建立A:

$~/dev/A/configure --prefix=~/dev/A-install
$make && make install

然后我建立B:

$~/dev/B/configure --prefix=~/dev/B-install --with-A=~/dev/A-install
$make && make install

然后我想将〜/ dev / A-install和〜/ dev / B-install的内容上传到我们的文件服务器,所以其他团队和构建机器可以使用二进制文件.但是当他们尝试使用B时,它们会得到链接器警告:

/usr/bin/ld: warning: libA.so.2,needed by /.../deps/B/lib/libB.so,not found (try using -rpath or -rpath-link)

当我运行ldd libB.so它给出:

...
libA.so.2 => /home/alex/dev/A-install/lib/libA.so.2

显然,这条路径只存在于我的机器上,不能在其他机器上找到.

如何从libB.so删除完整的硬编码路径?

谢谢.

解决方法

您必须使用–prefix值,这两个包将在运行时环境中有效!

比安装时,在make命令行上覆盖前缀或DESTDIR(前缀替换前缀,DESTDIR已经添加,但是更可靠).喜欢:

~/dev/A$./configure
~/dev/A$make 
~/dev/A$make install prefix=~/dev/A-install
~/dev/B$./configure --with-A=~/dev/A-install
~/dev/B$make
~/dev/B$make install prefix=~/dev/B-install

或(这是首选,并且是所有包装构建工具如何使用它):

~/dev/A$./configure
~/dev/A$make 
~/dev/A$make install DESTDIR=~/dev/A-install
~/dev/B$./configure --with-A=~/dev/A-install/usr/local
~/dev/B$make
~/dev/B$make install prefix=~/dev/B-install

因为这样你要安装到〜/ dev / A-install / $prefix,所以认前缀〜/ dev / A-install /usr/local.这个后续选项的优点是,如果您重新定义一些特定的安装路径而不引用前缀(例如–sysconfdir = / etc),则DESTDIR仍然会被添加到前缀中,而不会受到前缀的影响.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...