微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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仍然会被添加到前缀中,而不会受到前缀的影响.

原文地址:https://www.jb51.cc/c/114113.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐