【问题标题】:Cabal can't find foreign library when building on NixOSCabal 在 NixOS 上构建时找不到外国库
【发布时间】:2016-03-31 03:43:47
【问题描述】:

我正在尝试使用 cabal2nix 在 NixOS 上构建一个内部 Haskell 项目。它包装(并因此依赖于)一个外部库,在 Ubuntu 上将由 wgetting 源构建,然后运行 ​​make && make install && ldconfig。因此,当 cabal 去构建程序时,它显然能够找到适当的头文件(在 /usr/local/include/ta-lib/usr/include/ta-lib 中)。

在 Nix 上,我理解的过程是设置一个 .nix 文件来指定如何获取和构建源代码,然后 Nix 设置隔离的构建环境。当我这样做时,会正确获取并构建外部库。

当 Nix 运行配置步骤时,它看起来没问题:

configureFlags: --verbose --prefix=/nix/store/fwpw03bd0c2m5yb7v2wc7g6f0qj912ra-talib-0.1.0.0 --libdir=$prefix/lib/$compiler --libsubdir=$pkgid --with-gcc=gcc --package-db=/tmp/nix-build-talib-0.1.0.0.drv-0/package.conf.d --ghc-option=-optl=-Wl,-rpath=/nix/store/fwpw03bd0c2m5yb7v2wc7g6f0qj912ra-talib-0.1.0.0/lib/ghc-7.10.2/talib-0.1.0.0 --enable-split-objs --disable-library-profiling --disable-executable-profiling --enable-shared --enable-library-vanilla --enable-executable-dynamic --enable-tests --extra-include-dirs=/nix/store/gvglncjgd5yif9bc03qalmp2mrjp524n-ta-lib-0.4.0/include --extra-lib-dirs=/nix/store/gvglncjgd5yif9bc03qalmp2mrjp524n-ta-lib-0.4.0/lib

--extra-include-dirs--extra-lib-dirs 设置为Nix 商店中的正确路径。但是,当它开始构建时,它会抱怨,

Setup: Missing dependency on a foreign library:
* Missing C library: ta_lib

不幸的是,我不明白阴谋集团如何确定外国图书馆是否存在。我在这里 (Haskell how to resolve cabal error: Missing dependencies on foreign libraries?) 读到,cabal 将尝试构建和链接一个 C 程序,该程序由它找到的每个头文件组成。所以,不知何故,它没有找到正确的库。

怎么了?这是否与 Ubuntu 中运行 ldconfig 的步骤有关?

【问题讨论】:

标签: haskell cabal nixos nix


【解决方案1】:

问题在于ta_lib 依赖于系统数学库m,但默认情况下该库未链接。您可以通过创建存根 C 程序来检查这一点

echo "int main() { return 0; }" >test.c

并尝试将其与ta_lib 联系起来:

$ nix-shell -p ta_lib --run "gcc test.c -lta_lib"
/nix/store/ghinzmxfm2s41nz8y873jlywwmcbw38l-ta-lib-0.4.0/lib/libta_lib.so: undefined reference to `sinh'
/nix/store/ghinzmxfm2s41nz8y873jlywwmcbw38l-ta-lib-0.4.0/lib/libta_lib.so: undefined reference to `sincos'
[...]
collect2: error: ld returned 1 exit status

现在,当 Cabal 尝试确定库是否可用时,它会尝试将其链接到存根测试程序,但由于所有这些未定义的符号,该尝试将失败。因此,Cabal 抱怨该库无法链接(即使其路径已正确配置和设置)。

要解决该问题,请将 m 库添加到项目的 Cabal 文件中的 extra-libraries 属性中,如下所示:

extra-libraries: ta_lib, m

这应该会使 Cabal 配置阶段成功。

【讨论】:

  • 工作就像一个魅力。谢谢!
  • 我遇到了与python, python2 or pepper 相同的问题。 tar, jq 可以将它们添加到额外的库中不起作用。这是同一个问题吗?如果是这样,解决方法是什么?我一直在尝试这个建议,但没有成功。
  • 我也有同样的问题,但使用了像libmnl 这样的标准库,它是 Nixpkgs 的一部分。我运行相同的命令 gcc test.c -lmnl 并且它可以工作,但 Cabal 仍然找不到该程序。
猜你喜欢
  • 2018-06-21
  • 2017-01-28
  • 2018-01-30
  • 1970-01-01
  • 2019-08-13
  • 1970-01-01
  • 1970-01-01
  • 2021-02-26
  • 2016-06-14
相关资源
最近更新 更多