3
0
Fork 0
forked from mirrors/nixpkgs

guile-1.8: Fix and clean up libtool propagation fixes

Fixes #37548
This commit is contained in:
Michael Alan Dorman 2018-03-21 14:20:04 -04:00 committed by John Ericson
parent 3c6dcdb74e
commit 2119041dbf

View file

@ -24,19 +24,19 @@ stdenv.mkDerivation rec {
nativeBuildInputs = [ makeWrapper gawk pkgconfig ]; nativeBuildInputs = [ makeWrapper gawk pkgconfig ];
buildInputs = [ readline libtool ]; buildInputs = [ readline libtool ];
propagatedBuildInputs = [ gmp ]; 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
];
patches = [ ./cpp-4.5.patch ]; patches = [ ./cpp-4.5.patch ];
postInstall = ''
wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin"
'';
preBuild = ''
sed -e '/lt_dlinit/a lt_dladdsearchdir("'$out/lib'");' -i libguile/dynl.c
'';
# Guile needs patching to preset results for the configure tests # Guile needs patching to preset results for the configure tests
# about pthreads, which work only in native builds. # about pthreads, which work only in native builds.
preConfigure = '' preConfigure = ''
@ -45,6 +45,22 @@ stdenv.mkDerivation rec {
fi 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. # One test fails.
# ERROR: file: "libtest-asmobs", message: "file not found" # ERROR: file: "libtest-asmobs", message: "file not found"
# This is fixed here: # This is fixed here: