diff options
author | Michael Raskin <7c6f434c@mail.ru> | 2017-01-03 18:06:02 +0100 |
---|---|---|
committer | Michael Raskin <7c6f434c@mail.ru> | 2017-01-03 18:06:47 +0100 |
commit | efd2b279f3a9d8a86fa04bfa965c12efb48e8c65 (patch) | |
tree | d7457ef472fe44ce91fcd98a205f4ab1eb60fd48 /pkgs/development/compilers | |
parent | 95f3473e1849f03044b05be3ffaf86cb65e08238 (diff) | |
download | nixlib-efd2b279f3a9d8a86fa04bfa965c12efb48e8c65.tar nixlib-efd2b279f3a9d8a86fa04bfa965c12efb48e8c65.tar.gz nixlib-efd2b279f3a9d8a86fa04bfa965c12efb48e8c65.tar.bz2 nixlib-efd2b279f3a9d8a86fa04bfa965c12efb48e8c65.tar.lz nixlib-efd2b279f3a9d8a86fa04bfa965c12efb48e8c65.tar.xz nixlib-efd2b279f3a9d8a86fa04bfa965c12efb48e8c65.tar.zst nixlib-efd2b279f3a9d8a86fa04bfa965c12efb48e8c65.zip |
sbcl_1_3_12: init at 1.3.12; reinstating the previous version for Maxima
Diffstat (limited to 'pkgs/development/compilers')
-rw-r--r-- | pkgs/development/compilers/sbcl/1.3.12.nix | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/pkgs/development/compilers/sbcl/1.3.12.nix b/pkgs/development/compilers/sbcl/1.3.12.nix new file mode 100644 index 000000000000..8fa4741a4a14 --- /dev/null +++ b/pkgs/development/compilers/sbcl/1.3.12.nix @@ -0,0 +1,104 @@ +{ stdenv, fetchurl, writeText, sbclBootstrap +, sbclBootstrapHost ? "${sbclBootstrap}/bin/sbcl --disable-debugger --no-userinit --no-sysinit" +, threadSupport ? (stdenv.isi686 || stdenv.isx86_64) + # 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 +}: + +stdenv.mkDerivation rec { + name = "sbcl-${version}"; + version = "1.3.12"; + + src = fetchurl { + url = "mirror://sourceforge/project/sbcl/sbcl/${version}/${name}-source.tar.bz2"; + sha256 = "1hjr2xqazy4j0m58y4na6fz8ii3xflqairxy7vpd7ajbs00yqfc0"; + }; + + 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.isArm "(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 '/deftest pwent/inil' -i contrib/sb-posix/posix-tests.lisp + sed -e '/deftest grent/inil' -i contrib/sb-posix/posix-tests.lisp + sed -e '/deftest .*ent.non-existing/,+5d' -i contrib/sb-posix/posix-tests.lisp + sed -e '/deftest \(pw\|gr\)ent/,+3d' -i contrib/sb-posix/posix-tests.lisp + + 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 + '' + ); + + + preBuild = '' + export INSTALL_ROOT=$out + mkdir -p test-home + export HOME=$PWD/test-home + ''; + + buildPhase = '' + sh make.sh --prefix=$out --xc-host="${sbclBootstrapHost}" + ''; + + installPhase = '' + INSTALL_ROOT=$out sh install.sh + ''; + + # Specifying $SBCL_HOME is only truly needed with `purgeNixReferences = true`. + setupHook = writeText "setupHook.sh" '' + envHooks+=(_setSbclHome) + _setSbclHome() { + export SBCL_HOME='@out@/lib/sbcl/' + } + ''; + + meta = sbclBootstrap.meta // { + inherit version; + updateWalker = true; + }; +} |