guile_2_0: init at 2.0.13
Reinstate guile 2.0.x. Use it for autogen
This commit is contained in:
parent
f66e06a828
commit
0cf93fda07
120
pkgs/development/interpreters/guile/2.0.nix
Normal file
120
pkgs/development/interpreters/guile/2.0.nix
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
{ fetchurl, stdenv, libtool, readline, gmp, pkgconfig, boehmgc, libunistring
|
||||||
|
, libffi, gawk, makeWrapper, fetchpatch, coverageAnalysis ? null, gnu ? null }:
|
||||||
|
|
||||||
|
# Do either a coverage analysis build or a standard build.
|
||||||
|
(if coverageAnalysis != null
|
||||||
|
then coverageAnalysis
|
||||||
|
else stdenv.mkDerivation)
|
||||||
|
|
||||||
|
(rec {
|
||||||
|
name = "guile-2.0.13";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "mirror://gnu/guile/${name}.tar.xz";
|
||||||
|
sha256 = "12yqkr974y91ylgw6jnmci2v90i90s7h9vxa4zk0sai8vjnz4i1p";
|
||||||
|
};
|
||||||
|
|
||||||
|
outputs = [ "out" "dev" "info" ];
|
||||||
|
setOutputFlags = false; # $dev gets into the library otherwise
|
||||||
|
|
||||||
|
nativeBuildInputs = [ makeWrapper gawk pkgconfig ];
|
||||||
|
buildInputs = [ readline libtool libunistring libffi ];
|
||||||
|
propagatedBuildInputs = [ gmp boehmgc ]
|
||||||
|
|
||||||
|
# XXX: These ones aren't normally needed here, but since
|
||||||
|
# `libguile-2.0.la' reads `-lltdl -lunistring', adding them here will add
|
||||||
|
# the needed `-L' flags. As for why the `.la' file lacks the `-L' flags,
|
||||||
|
# see below.
|
||||||
|
++ [ libtool libunistring ];
|
||||||
|
|
||||||
|
# A native Guile 2.0 is needed to cross-build Guile.
|
||||||
|
selfNativeBuildInput = true;
|
||||||
|
|
||||||
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
patches = [ ./disable-gc-sensitive-tests.patch ./eai_system.patch ./clang.patch
|
||||||
|
(fetchpatch {
|
||||||
|
# Fixes stability issues with 00-repl-server.test
|
||||||
|
url = "http://git.savannah.gnu.org/cgit/guile.git/patch/?id=2fbde7f02adb8c6585e9baf6e293ee49cd23d4c4";
|
||||||
|
sha256 = "0p6c1lmw1iniq03z7x5m65kg3lq543kgvdb4nrxsaxjqf3zhl77v";
|
||||||
|
})
|
||||||
|
] ++
|
||||||
|
(stdenv.lib.optional (coverageAnalysis != null) ./gcov-file-name.patch);
|
||||||
|
|
||||||
|
# Explicitly link against libgcc_s, to work around the infamous
|
||||||
|
# "libgcc_s.so.1 must be installed for pthread_cancel to work".
|
||||||
|
|
||||||
|
# don't have "libgcc_s.so.1" on darwin
|
||||||
|
LDFLAGS = stdenv.lib.optionalString (!stdenv.isDarwin) "-lgcc_s";
|
||||||
|
|
||||||
|
configureFlags = [ "--with-libreadline-prefix" ]
|
||||||
|
++ stdenv.lib.optionals stdenv.isSunOS [
|
||||||
|
# Make sure the right <gmp.h> is found, and not the incompatible
|
||||||
|
# /usr/include/mp.h from OpenSolaris. See
|
||||||
|
# <https://lists.gnu.org/archive/html/hydra-users/2012-08/msg00000.html>
|
||||||
|
# for details.
|
||||||
|
"--with-libgmp-prefix=${gmp.dev}"
|
||||||
|
|
||||||
|
# Same for these (?).
|
||||||
|
"--with-libreadline-prefix=${readline.dev}"
|
||||||
|
"--with-libunistring-prefix=${libunistring}"
|
||||||
|
|
||||||
|
# See below.
|
||||||
|
"--without-threads"
|
||||||
|
];
|
||||||
|
|
||||||
|
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-2.0.pc" \
|
||||||
|
-e "s|-lunistring|-L${libunistring}/lib -lunistring|g ;
|
||||||
|
s|^Cflags:\(.*\)$|Cflags: -I${libunistring}/include \1|g ;
|
||||||
|
s|-lltdl|-L${libtool.lib}/lib -lltdl|g ;
|
||||||
|
s|includedir=$out|includedir=$dev|g
|
||||||
|
"
|
||||||
|
'';
|
||||||
|
|
||||||
|
# make check doesn't work on darwin
|
||||||
|
# On Linuxes+Hydra the tests are flaky; feel free to investigate deeper.
|
||||||
|
doCheck = false;
|
||||||
|
|
||||||
|
setupHook = ./setup-hook-2.0.sh;
|
||||||
|
|
||||||
|
crossAttrs.preConfigure =
|
||||||
|
stdenv.lib.optionalString (stdenv.cross.config == "i586-pc-gnu")
|
||||||
|
# On GNU, libgc depends on libpthread, but the cross linker doesn't
|
||||||
|
# know where to find libpthread, which leads to erroneous test failures
|
||||||
|
# in `configure', where `-pthread' and `-lpthread' aren't explicitly
|
||||||
|
# passed. So it needs some help (XXX).
|
||||||
|
"export LDFLAGS=-Wl,-rpath-link=${gnu.libpthreadCross}/lib";
|
||||||
|
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Embeddable Scheme implementation";
|
||||||
|
homepage = http://www.gnu.org/software/guile/;
|
||||||
|
license = stdenv.lib.licenses.lgpl3Plus;
|
||||||
|
maintainers = with stdenv.lib.maintainers; [ ludo lovek323 ];
|
||||||
|
platforms = stdenv.lib.platforms.all;
|
||||||
|
|
||||||
|
longDescription = ''
|
||||||
|
GNU Guile is an implementation of the Scheme programming language, with
|
||||||
|
support for many SRFIs, packaged for use in a wide variety of
|
||||||
|
environments. In addition to implementing the R5RS Scheme standard
|
||||||
|
and a large subset of R6RS, Guile includes a module system, full access
|
||||||
|
to POSIX system calls, networking support, multiple threads, dynamic
|
||||||
|
linking, a foreign function call interface, and powerful string
|
||||||
|
processing.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
|
//
|
||||||
|
|
||||||
|
(stdenv.lib.optionalAttrs (!stdenv.isLinux) {
|
||||||
|
# Work around <http://bugs.gnu.org/14201>.
|
||||||
|
SHELL = "/bin/sh";
|
||||||
|
CONFIG_SHELL = "/bin/sh";
|
||||||
|
})
|
14
pkgs/development/interpreters/guile/clang.patch
Normal file
14
pkgs/development/interpreters/guile/clang.patch
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
diff --git a/lib/stdint.in.h b/lib/stdint.in.h
|
||||||
|
index 889bca7..15d39b0 100644
|
||||||
|
--- a/lib/stdint.in.h
|
||||||
|
+++ b/lib/stdint.in.h
|
||||||
|
@@ -74,7 +74,8 @@
|
||||||
|
in <inttypes.h> would reinclude us, skipping our contents because
|
||||||
|
_@GUARD_PREFIX@_STDINT_H is defined.
|
||||||
|
The include_next requires a split double-inclusion guard. */
|
||||||
|
-# @INCLUDE_NEXT@ @NEXT_STDINT_H@
|
||||||
|
+# include <inttypes.h>
|
||||||
|
+// # @INCLUDE_NEXT@ @NEXT_STDINT_H@
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if ! defined _@GUARD_PREFIX@_STDINT_H && ! defined _GL_JUST_INCLUDE_SYSTEM_STDINT_H
|
@ -0,0 +1,25 @@
|
|||||||
|
This patch disable GC-sensitive tests. This is particularly useful when
|
||||||
|
compiling with `-O0' (as is done with coverage analysis) since there may
|
||||||
|
be many false references held on the stack, leading to the failure of
|
||||||
|
such tests.
|
||||||
|
|
||||||
|
--- a/test-suite/tests/gc.test
|
||||||
|
+++ b/test-suite/tests/gc.test
|
||||||
|
@@ -67,6 +67,7 @@
|
||||||
|
|
||||||
|
(with-test-prefix "gc"
|
||||||
|
(pass-if "Unused modules are removed"
|
||||||
|
+ (throw 'unresolved)
|
||||||
|
(let* ((guard (make-guardian))
|
||||||
|
(total 1000))
|
||||||
|
|
||||||
|
--- a/test-suite/tests/threads.test
|
||||||
|
+++ b/test-suite/tests/threads.test
|
||||||
|
@@ -366,6 +366,7 @@
|
||||||
|
(not (mutex-owner m))))
|
||||||
|
|
||||||
|
(pass-if "mutex with owner not retained (bug #27450)"
|
||||||
|
+ (throw 'unresolved)
|
||||||
|
(let ((g (make-guardian)))
|
||||||
|
(g (let ((m (make-mutex))) (lock-mutex m) m))
|
||||||
|
|
13
pkgs/development/interpreters/guile/setup-hook-2.0.sh
Normal file
13
pkgs/development/interpreters/guile/setup-hook-2.0.sh
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
addGuileLibPath () {
|
||||||
|
if test -d "$1/share/guile/site/2.0"
|
||||||
|
then
|
||||||
|
export GUILE_LOAD_PATH="${GUILE_LOAD_PATH}${GUILE_LOAD_PATH:+:}$1/share/guile/site/2.0"
|
||||||
|
export GUILE_LOAD_COMPILED_PATH="${GUILE_LOAD_COMPILED_PATH}${GUILE_LOAD_COMPILED_PATH:+:}$1/share/guile/site/2.0"
|
||||||
|
elif test -d "$1/share/guile/site"
|
||||||
|
then
|
||||||
|
export GUILE_LOAD_PATH="${GUILE_LOAD_PATH}${GUILE_LOAD_PATH:+:}$1/share/guile/site"
|
||||||
|
export GUILE_LOAD_COMPILED_PATH="${GUILE_LOAD_COMPILED_PATH}${GUILE_LOAD_COMPILED_PATH:+:}$1/share/guile/site"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
envHooks+=(addGuileLibPath)
|
@ -574,7 +574,9 @@ with pkgs;
|
|||||||
|
|
||||||
atftp = callPackage ../tools/networking/atftp { };
|
atftp = callPackage ../tools/networking/atftp { };
|
||||||
|
|
||||||
autogen = callPackage ../development/tools/misc/autogen { };
|
autogen = callPackage ../development/tools/misc/autogen {
|
||||||
|
guile = guile_2_0;
|
||||||
|
};
|
||||||
|
|
||||||
autojump = callPackage ../tools/misc/autojump { };
|
autojump = callPackage ../tools/misc/autojump { };
|
||||||
|
|
||||||
@ -5792,6 +5794,9 @@ with pkgs;
|
|||||||
|
|
||||||
guile_1_8 = callPackage ../development/interpreters/guile/1.8.nix { };
|
guile_1_8 = callPackage ../development/interpreters/guile/1.8.nix { };
|
||||||
|
|
||||||
|
# Needed for autogen
|
||||||
|
guile_2_0 = callPackage ../development/interpreters/guile/2.0.nix { };
|
||||||
|
|
||||||
guile_2_2 = callPackage ../development/interpreters/guile { };
|
guile_2_2 = callPackage ../development/interpreters/guile { };
|
||||||
|
|
||||||
guile = guile_2_2;
|
guile = guile_2_2;
|
||||||
|
Loading…
Reference in New Issue
Block a user