summaryrefslogtreecommitdiffstats
path: root/pkgs/development/interpreters/guile
diff options
context:
space:
mode:
authorMichael Alan Dorman <mdorman@ironicdesign.com>2018-03-21 14:20:04 -0400
committerJohn Ericson <John.Ericson@Obsidian.Systems>2018-05-13 11:36:29 -0400
commit9a4cc93522aeee59fafe01bcba65d1675675f9d6 (patch)
tree31cc57576d4fdf5a2e304ea64553187fad9dbdd5 /pkgs/development/interpreters/guile
parent8415682658752910f9142165d483f861aa8d99be (diff)
guile-1.8: Fix and clean up `libtool` propagation fixes
Fixes #37548 (cherry picked from commit 2119041dbf4323ff3e92e605b70b75fc2c252741)
Diffstat (limited to 'pkgs/development/interpreters/guile')
-rw-r--r--pkgs/development/interpreters/guile/1.8.nix34
1 files changed, 25 insertions, 9 deletions
diff --git a/pkgs/development/interpreters/guile/1.8.nix b/pkgs/development/interpreters/guile/1.8.nix
index 6a2fdbdea436..cf42c9a7b683 100644
--- a/pkgs/development/interpreters/guile/1.8.nix
+++ b/pkgs/development/interpreters/guile/1.8.nix
@@ -24,18 +24,18 @@ stdenv.mkDerivation rec {
nativeBuildInputs = [ makeWrapper gawk pkgconfig ];
buildInputs = [ readline libtool ];
- propagatedBuildInputs = [ gmp ];
-
- patches = [ ./cpp-4.5.patch ];
+ propagatedBuildInputs = [
+ gmp
+ # XXX: These ones aren't normally needed here, but `libguile*.la' has '-l'
+ # flags for them without corresponding '-L' flags. Adding them here will add
+ # the needed `-L' flags. As for why the `.la' file lacks the `-L' flags,
+ # see below.
+ libtool
+ ];
- postInstall = ''
- wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin"
- '';
- preBuild = ''
- sed -e '/lt_dlinit/a lt_dladdsearchdir("'$out/lib'");' -i libguile/dynl.c
- '';
+ patches = [ ./cpp-4.5.patch ];
# Guile needs patching to preset results for the configure tests
# about pthreads, which work only in native builds.
@@ -45,6 +45,22 @@ stdenv.mkDerivation rec {
fi
'';
+ preBuild = ''
+ sed -e '/lt_dlinit/a lt_dladdsearchdir("'$out/lib'");' -i libguile/dynl.c
+ '';
+
+
+ postInstall = ''
+ wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin"
+ ''
+ # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for
+ # why `--with-libunistring-prefix' and similar options coming from
+ # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64.
+ + ''
+ sed -i "$out/lib/pkgconfig/guile"-*.pc \
+ -e "s|-lltdl|-L${libtool.lib}/lib -lltdl|g"
+ '';
+
# One test fails.
# ERROR: file: "libtest-asmobs", message: "file not found"
# This is fixed here: