chez-scheme: 9.5-20171109 -> 9.5.1
- Add a new postInstall hook that installs Chez's kernel.o file into the library directory. This library /should/ be installed by Chez, but isn't, and it's the only way to properly embed Chez in your applications or write your own shell/bootfile harness directly. - Fixes the version number for Nix to properly reflect the one Chez shows the user. - Loose odds and ends (fix homepage URL, tidy up comments) Signed-off-by: Austin Seipp <aseipp@pobox.com>
This commit is contained in:
parent
3b4bd3ea9f
commit
df689d142b
@ -2,8 +2,7 @@
|
|||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "chez-scheme-${version}";
|
name = "chez-scheme-${version}";
|
||||||
version = "9.5-${dver}";
|
version = "9.5.1";
|
||||||
dver = "20171109";
|
|
||||||
|
|
||||||
src = fetchgit {
|
src = fetchgit {
|
||||||
url = "https://github.com/cisco/chezscheme.git";
|
url = "https://github.com/cisco/chezscheme.git";
|
||||||
@ -13,10 +12,12 @@ stdenv.mkDerivation rec {
|
|||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ coreutils ] ++ stdenv.lib.optional stdenv.isDarwin cctools;
|
nativeBuildInputs = [ coreutils ] ++ stdenv.lib.optional stdenv.isDarwin cctools;
|
||||||
|
|
||||||
buildInputs = [ ncurses libiconv libX11 ];
|
buildInputs = [ ncurses libiconv libX11 ];
|
||||||
|
|
||||||
/* We patch out a very annoying 'feature' in ./configure, which
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
/*
|
||||||
|
** We patch out a very annoying 'feature' in ./configure, which
|
||||||
** tries to use 'git' to update submodules.
|
** tries to use 'git' to update submodules.
|
||||||
**
|
**
|
||||||
** We have to also fix a few occurrences to tools with absolute
|
** We have to also fix a few occurrences to tools with absolute
|
||||||
@ -38,19 +39,47 @@ stdenv.mkDerivation rec {
|
|||||||
--replace "/usr/bin/libtool" libtool
|
--replace "/usr/bin/libtool" libtool
|
||||||
'';
|
'';
|
||||||
|
|
||||||
/* Don't use configureFlags, since that just implicitly appends
|
/*
|
||||||
|
** Don't use configureFlags, since that just implicitly appends
|
||||||
** everything onto a --prefix flag, which ./configure gets very angry
|
** everything onto a --prefix flag, which ./configure gets very angry
|
||||||
** about.
|
** about.
|
||||||
|
**
|
||||||
|
** Also, carefully set a manual workarea argument, so that we
|
||||||
|
** can later easily find the machine type that we built Chez
|
||||||
|
** for.
|
||||||
*/
|
*/
|
||||||
configurePhase = ''
|
configurePhase = ''
|
||||||
./configure --threads --installprefix=$out --installman=$out/share/man
|
./configure --threads \
|
||||||
|
--installprefix=$out --installman=$out/share/man \
|
||||||
|
--workarea=work
|
||||||
'';
|
'';
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
/*
|
||||||
|
** Install the kernel.o file, so we can compile C applications that
|
||||||
|
** link directly to the Chez runtime (for booting their own files, or
|
||||||
|
** embedding.)
|
||||||
|
**
|
||||||
|
** Ideally in the future this would be less of a hack and could be
|
||||||
|
** done by Chez itself. Alternatively, there could just be a big
|
||||||
|
** case statement matching to the different stdenv.platform values...
|
||||||
|
*/
|
||||||
|
postInstall = ''
|
||||||
|
m="$(ls ./work/boot)"
|
||||||
|
if [ "x''${m[1]}" != "x" ]; then
|
||||||
|
>&2 echo "ERROR: more than one bootfile build found; this is a nixpkgs error"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
kernel=./work/boot/$m/kernel.o
|
||||||
|
kerneldest=$out/lib/csv${version}/$m/
|
||||||
|
|
||||||
|
echo installing $kernel to $kerneldest
|
||||||
|
cp $kernel $kerneldest/kernel.o
|
||||||
|
'';
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
description = "A powerful and incredibly fast R6RS Scheme compiler";
|
description = "A powerful and incredibly fast R6RS Scheme compiler";
|
||||||
homepage = "http://www.scheme.com";
|
homepage = https://cisco.github.io/ChezScheme/;
|
||||||
license = stdenv.lib.licenses.asl20;
|
license = stdenv.lib.licenses.asl20;
|
||||||
platforms = stdenv.lib.platforms.unix;
|
platforms = stdenv.lib.platforms.unix;
|
||||||
maintainers = with stdenv.lib.maintainers; [ thoughtpolice ];
|
maintainers = with stdenv.lib.maintainers; [ thoughtpolice ];
|
||||||
|
Loading…
Reference in New Issue
Block a user