我需要建立两个第三方共享库,所以他们的.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仍然会被添加到前缀中,而不会受到前缀的影响.