mirror of
https://github.com/SebastianWendel/nixpkgs.git
synced 2024-09-21 04:49:01 +02:00
sbcl: reinstate 2.0.0; add sbcl_2_0_1 for 2.0.1
2.0.1 is too fresh for current Quicklisp (for example, CFFI fails)
This commit is contained in:
parent
49fb456ece
commit
1f0b4b19aa
112
pkgs/development/compilers/sbcl/2.0.0.nix
Normal file
112
pkgs/development/compilers/sbcl/2.0.0.nix
Normal file
|
@ -0,0 +1,112 @@
|
||||||
|
{ stdenv, fetchurl, writeText, sbclBootstrap
|
||||||
|
, sbclBootstrapHost ? "${sbclBootstrap}/bin/sbcl --disable-debugger --no-userinit --no-sysinit"
|
||||||
|
, threadSupport ? (stdenv.isi686 || stdenv.isx86_64 || "aarch64-linux" == stdenv.hostPlatform.system)
|
||||||
|
# Meant for sbcl used for creating binaries portable to non-NixOS via save-lisp-and-die.
|
||||||
|
# Note that the created binaries still need `patchelf --set-interpreter ...`
|
||||||
|
# to get rid of ${glibc} dependency.
|
||||||
|
, purgeNixReferences ? false
|
||||||
|
, texinfo
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
pname = "sbcl";
|
||||||
|
version = "2.0.0";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "mirror://sourceforge/project/sbcl/sbcl/${version}/${pname}-${version}-source.tar.bz2";
|
||||||
|
sha256 = "1krgd69cirp4ili2pfsh1a0mfvq722jbknlvmf17qhsxh1b94dlh";
|
||||||
|
};
|
||||||
|
|
||||||
|
buildInputs = [texinfo];
|
||||||
|
|
||||||
|
patchPhase = ''
|
||||||
|
echo '"${version}.nixos"' > version.lisp-expr
|
||||||
|
echo "
|
||||||
|
(lambda (features)
|
||||||
|
(flet ((enable (x)
|
||||||
|
(pushnew x features))
|
||||||
|
(disable (x)
|
||||||
|
(setf features (remove x features))))
|
||||||
|
''
|
||||||
|
+ (if threadSupport then "(enable :sb-thread)" else "(disable :sb-thread)")
|
||||||
|
+ stdenv.lib.optionalString stdenv.isAarch32 "(enable :arm)"
|
||||||
|
+ ''
|
||||||
|
)) " > customize-target-features.lisp
|
||||||
|
|
||||||
|
pwd
|
||||||
|
|
||||||
|
# SBCL checks whether files are up-to-date in many places..
|
||||||
|
# Unfortunately, same timestamp is not good enough
|
||||||
|
sed -e 's@> x y@>= x y@' -i contrib/sb-aclrepl/repl.lisp
|
||||||
|
#sed -e '/(date)/i((= date 2208988801) 2208988800)' -i contrib/asdf/asdf.lisp
|
||||||
|
sed -i src/cold/slam.lisp -e \
|
||||||
|
'/file-write-date input/a)'
|
||||||
|
sed -i src/cold/slam.lisp -e \
|
||||||
|
'/file-write-date output/i(or (and (= 2208988801 (file-write-date output)) (= 2208988801 (file-write-date input)))'
|
||||||
|
sed -i src/code/target-load.lisp -e \
|
||||||
|
'/date defaulted-fasl/a)'
|
||||||
|
sed -i src/code/target-load.lisp -e \
|
||||||
|
'/date defaulted-source/i(or (and (= 2208988801 (file-write-date defaulted-source-truename)) (= 2208988801 (file-write-date defaulted-fasl-truename)))'
|
||||||
|
|
||||||
|
# Fix the tests
|
||||||
|
sed -e '5,$d' -i contrib/sb-bsd-sockets/tests.lisp
|
||||||
|
sed -e '5,$d' -i contrib/sb-simple-streams/*test*.lisp
|
||||||
|
|
||||||
|
# Use whatever `cc` the stdenv provides
|
||||||
|
substituteInPlace src/runtime/Config.x86-64-darwin --replace gcc cc
|
||||||
|
|
||||||
|
substituteInPlace src/runtime/Config.x86-64-darwin \
|
||||||
|
--replace mmacosx-version-min=10.4 mmacosx-version-min=10.5
|
||||||
|
''
|
||||||
|
+ (if purgeNixReferences
|
||||||
|
then
|
||||||
|
# This is the default location to look for the core; by default in $out/lib/sbcl
|
||||||
|
''
|
||||||
|
sed 's@^\(#define SBCL_HOME\) .*$@\1 "/no-such-path"@' \
|
||||||
|
-i src/runtime/runtime.c
|
||||||
|
''
|
||||||
|
else
|
||||||
|
# Fix software version retrieval
|
||||||
|
''
|
||||||
|
sed -e "s@/bin/uname@$(command -v uname)@g" -i src/code/*-os.lisp \
|
||||||
|
src/code/run-program.lisp
|
||||||
|
''
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
preBuild = ''
|
||||||
|
export INSTALL_ROOT=$out
|
||||||
|
mkdir -p test-home
|
||||||
|
export HOME=$PWD/test-home
|
||||||
|
'';
|
||||||
|
|
||||||
|
buildPhase = ''
|
||||||
|
sh make.sh --prefix=$out --xc-host="${sbclBootstrapHost}"
|
||||||
|
(cd doc/manual ; make info)
|
||||||
|
'';
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
INSTALL_ROOT=$out sh install.sh
|
||||||
|
''
|
||||||
|
+ stdenv.lib.optionalString (!purgeNixReferences) ''
|
||||||
|
cp -r src $out/lib/sbcl
|
||||||
|
cp -r contrib $out/lib/sbcl
|
||||||
|
cat >$out/lib/sbcl/sbclrc <<EOF
|
||||||
|
(setf (logical-pathname-translations "SYS")
|
||||||
|
'(("SYS:SRC;**;*.*.*" #P"$out/lib/sbcl/src/**/*.*")
|
||||||
|
("SYS:CONTRIB;**;*.*.*" #P"$out/lib/sbcl/contrib/**/*.*")))
|
||||||
|
EOF
|
||||||
|
'';
|
||||||
|
|
||||||
|
setupHook = stdenv.lib.optional purgeNixReferences (writeText "setupHook.sh" ''
|
||||||
|
addEnvHooks "$targetOffset" _setSbclHome
|
||||||
|
_setSbclHome() {
|
||||||
|
export SBCL_HOME='@out@/lib/sbcl/'
|
||||||
|
}
|
||||||
|
'');
|
||||||
|
|
||||||
|
meta = sbclBootstrap.meta // {
|
||||||
|
inherit version;
|
||||||
|
updateWalker = true;
|
||||||
|
};
|
||||||
|
}
|
|
@ -8831,7 +8831,8 @@ in
|
||||||
sagittarius-scheme = callPackage ../development/compilers/sagittarius-scheme {};
|
sagittarius-scheme = callPackage ../development/compilers/sagittarius-scheme {};
|
||||||
|
|
||||||
sbclBootstrap = callPackage ../development/compilers/sbcl/bootstrap.nix {};
|
sbclBootstrap = callPackage ../development/compilers/sbcl/bootstrap.nix {};
|
||||||
sbcl = callPackage ../development/compilers/sbcl {};
|
sbcl_2_0_1 = callPackage ../development/compilers/sbcl {};
|
||||||
|
sbcl = callPackage ../development/compilers/sbcl/2.0.0.nix {};
|
||||||
|
|
||||||
scala_2_10 = callPackage ../development/compilers/scala/2.10.nix { };
|
scala_2_10 = callPackage ../development/compilers/scala/2.10.nix { };
|
||||||
scala_2_11 = callPackage ../development/compilers/scala/2.11.nix { };
|
scala_2_11 = callPackage ../development/compilers/scala/2.11.nix { };
|
||||||
|
|
Loading…
Reference in a new issue