c - libreadline.so.7 : undefined symbol: UP

标签 c shared-libraries readline autotools

使用 GNU 时,我在从源代码构建 cURL 和 Git 时遇到问题 Readline 7 。当配置像 cURL 这样的库时,结果是:

$ ./configure ...
...
checking that generated files are newer than configure... done
configure: creating ./config.status
config.status: creating Makefile
gawk: symbol lookup error: /usr/local/lib64/libreadline.so.7: undefined symbol: UP
config.status: error: could not create Makefile
Failed to configure cURL

果然:

$ nm -D /usr/local/lib64/libreadline.so | egrep 'UP|DOWN|LEFT|RIGHT'
    U UP

还有:

$ nm /usr/local/lib64/libreadline.a | egrep 'UP|DOWN|LEFT|RIGHT'
    U UP

现在,奇怪的是,消息gawk:符号查找错误:/usr/local/lib64/libreadline.so.7: undefined symbol :UP undefined symbol :UP 不会出现在cURL的config.log中。它几乎就像 Autotools 命令正在生成它,而不是配置测试脚本。

Readline 的 CHANGE日志和README不要讨论更改或丢失的符号。我发现其他用户也遇到了同样的问题,但修复通常会退化为降级到 readline 6.3。

此时我不确定这是否是 Readline 问题;或者程序或库(如 cURL 或 Git)中的问题。因为该符号在 Readline 中未定义,所以我认为它更接近 Readline 问题(或 Readline 依赖的库)。

我的第一个问题是,我应该从哪里开始寻找问题?

我的第二个问题是,我们应该如何解决它?

<小时/>

这是 cURL 的 config.log 的相关部分。没有尾部,也没有测试,因为 cURL 似乎没有测试它或者它没有被记录。甚至日志中也缺少错误字符串。

$ cat curl-7.56.0/config.log
This file contains any messages produced by compilers while
running configure, to aid debugging if configure makes a mistake.

  $ ./configure --prefix=/usr/local --libdir=/usr/local/lib64 --enable-shared --
enable-static --enable-optimize --enable-symbol-hiding --enable-http --enable-ft
p --enable-file --enable-ldap --enable-ldaps --enable-rtsp --enable-proxy --enab
le-dict --enable-telnet --enable-tftp --enable-pop3 --enable-imap --enable-smb -
-enable-smtp --enable-gopher --enable-cookies --enable-ipv6 --with-zlib=/usr/loc
al --with-ssl=/usr/local --without-gnutls --without-polarssl --without-mbedtls -
-without-cyassl --without-nss --without-libssh2 --with-libidn2=/usr/local --with
-nghttp2 --with-ca-path=/etc/ssl/certs/ --with-ca-bundle=/etc/ssl/certs/ca-bundl
e.crt

...
<小时/>

为了完整起见,我没有从源代码构建 awkgawkmawk 并将它们安装在某处。 gawk 是 Fedora 26 的标准版本,它不使用 /usr/local/lib64 中的库:

Build-Scripts$ command -v gawk
/bin/gawk

Build-Scripts$ ldd /bin/gawk
    linux-vdso.so.1 (0x00007ffc33d2d000)
    libsigsegv.so.2 => /lib64/libsigsegv.so.2 (0x00007f3da9135000)
    libreadline.so.7 => /lib64/libreadline.so.7 (0x00007f3da8ee9000)
    libmpfr.so.4 => /lib64/libmpfr.so.4 (0x00007f3da8c87000)
    libgmp.so.10 => /lib64/libgmp.so.10 (0x00007f3da8a10000)
    libdl.so.2 => /lib64/libdl.so.2 (0x00007f3da880c000)
    libm.so.6 => /lib64/libm.so.6 (0x00007f3da84f6000)
    libc.so.6 => /lib64/libc.so.6 (0x00007f3da8125000)
    libtinfo.so.6 => /lib64/libtinfo.so.6 (0x00007f3da7ef9000)
    /lib64/ld-linux-x86-64.so.2 (0x00007f3da95e0000)

最佳答案

最近怎么样?

符号 UP 在 lib_termcap.c 和 lib_termcap.o 中定义 在库 libncurses.so 和 libncurses.a 中 在 ncurses 包中

包读取行需要诅咒。 ncurses 是“新诅咒”。

$ nm -D lib/libncurses.so | grep -w UP
000000000025f6c8 B UP

您必须使用 --with-shared 来编译共享对象库。

./configure --prefix=/u01/sw --with-shared
make

关于c - libreadline.so.7 : undefined symbol: UP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46881581/

相关文章:

c++ - 链接器如何处理链接到共享库的 C++ 静态库的唯一类型信息约束?

C# - SerialPort.ReadLine() 卡住我的程序

postgresql - 返回 Homebrew 中的 readline 版本 6.x 以修复 Postgresql?

c - # 表示数字 x 所需的位数

c++ - 如何减少编译时间 : in case of including an untouched header file

c - 此代码是否 ungetch() '\n' ?

ruby - Readline、输入记录分隔符和 Ruby

c - Strcmp 未将数组与字符串 "abc"进行比较

c - 使用数组作为指向字符串的指针来确定 int、double 的数据类型