diff options
author | Matthew Kennedy <mkennedy@gentoo.org> | 2005-10-23 19:46:25 +0000 |
---|---|---|
committer | Matthew Kennedy <mkennedy@gentoo.org> | 2005-10-23 19:46:25 +0000 |
commit | 4decd82696604e95494a84d9589930531747bd9a (patch) | |
tree | 0609011881ac17dc58516f2b97325ef180087d16 /dev-lisp/sbcl | |
parent | Version bump (diff) | |
download | gentoo-2-4decd82696604e95494a84d9589930531747bd9a.tar.gz gentoo-2-4decd82696604e95494a84d9589930531747bd9a.tar.bz2 gentoo-2-4decd82696604e95494a84d9589930531747bd9a.zip |
New upstream version; Revise metadata.xml for recent changes in NPTL/Linux 2.6 threading support changes; Resolves Bug #110046.
(Portage version: 2.0.53_rc5)
Diffstat (limited to 'dev-lisp/sbcl')
-rw-r--r-- | dev-lisp/sbcl/ChangeLog | 14 | ||||
-rw-r--r-- | dev-lisp/sbcl/Manifest | 53 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.9.5/README.Gentoo | 30 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-prefix | 5 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-suffix | 2 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.9.5/install-clc.lisp | 34 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.9.5/sbcl-gentoo.patch | 70 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.9.5/sbcl.sh | 60 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.9.5/sbclrc | 18 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/digest-sbcl-0.9.5 | 7 | ||||
-rw-r--r-- | dev-lisp/sbcl/metadata.xml | 25 | ||||
-rw-r--r-- | dev-lisp/sbcl/sbcl-0.9.5.ebuild | 172 |
12 files changed, 448 insertions, 42 deletions
diff --git a/dev-lisp/sbcl/ChangeLog b/dev-lisp/sbcl/ChangeLog index e0df890ba3f1..4d4c5cc9a7f2 100644 --- a/dev-lisp/sbcl/ChangeLog +++ b/dev-lisp/sbcl/ChangeLog @@ -1,6 +1,18 @@ # ChangeLog for dev-lisp/sbcl # Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/ChangeLog,v 1.72 2005/09/21 17:23:15 gustavoz Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/ChangeLog,v 1.73 2005/10/23 19:46:25 mkennedy Exp $ + +*sbcl-0.9.5 (23 Oct 2005) + + 23 Oct 2005; Matthew Kennedy <mkennedy@gentoo.org> + +files/0.9.5/README.Gentoo, + +files/0.9.5/customize-target-features.lisp-prefix, + +files/0.9.5/customize-target-features.lisp-suffix, + +files/0.9.5/install-clc.lisp, +files/0.9.5/sbcl.sh, + +files/0.9.5/sbcl-gentoo.patch, +files/0.9.5/sbclrc, metadata.xml, + +sbcl-0.9.5.ebuild: + New upstream version; Revise metadata.xml for recent changes in NPTL/Linux + 2.6 threading support changes; Resolves Bug #110046. 21 Sep 2005; Gustavo Zacarias <gustavoz@gentoo.org> sbcl-0.9.4.ebuild: Stable on sparc diff --git a/dev-lisp/sbcl/Manifest b/dev-lisp/sbcl/Manifest index ef983ee3e3d7..da24beb26882 100644 --- a/dev-lisp/sbcl/Manifest +++ b/dev-lisp/sbcl/Manifest @@ -1,30 +1,29 @@ ------BEGIN PGP SIGNED MESSAGE----- -Hash: SHA1 - -MD5 87f41f552f3b4d9f8e4ea7d7c9b2f8ee ChangeLog 21110 -MD5 845ba0e216f2adf5eb504a5eb06b9037 sbcl-0.9.4.ebuild 5046 -MD5 0c9bf11185a2a2f1916fc3dc72c0e89e metadata.xml 1037 -MD5 4b4f52ef8ceb0eb77b6976520c78f719 sbcl-0.9.3.ebuild 5046 -MD5 41c44af5374afae0f627457c2406ce35 files/digest-sbcl-0.9.3 557 -MD5 d118e40afe2da4c015ff893db4ae12c3 files/digest-sbcl-0.9.4 557 -MD5 5adaa789503e3fecd45ee5724d33584c files/0.9.4/sbcl-gentoo.patch 3810 -MD5 7b753c4f6f63f1fc8630f3c9100a8ca9 files/0.9.4/customize-target-features.lisp-suffix 8 -MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.9.4/sbcl.sh 1512 -MD5 653f804ebcd167d167f8163756b7da17 files/0.9.4/sbclrc 639 -MD5 3869dca83085d07e01386eda00c05943 files/0.9.4/install-clc.lisp 980 -MD5 683427165f7d0717333bbb9762972b8d files/0.9.4/customize-target-features.lisp-prefix 95 -MD5 da8c0ba7c4f5f9e9924953290d266070 files/0.9.4/README.Gentoo 1060 -MD5 fa37ba308cbdad5cf330525fd1ebcd28 files/0.9.3/sbcl-gentoo.patch 3810 +MD5 a85a7b4353f642f3183f2bdbd6eb2c1f ChangeLog 21607 +MD5 a525c50480694091f6a6688c1472ab10 files/0.9.3/README.Gentoo 1060 +MD5 683427165f7d0717333bbb9762972b8d files/0.9.3/customize-target-features.lisp-prefix 95 MD5 7b753c4f6f63f1fc8630f3c9100a8ca9 files/0.9.3/customize-target-features.lisp-suffix 8 +MD5 3869dca83085d07e01386eda00c05943 files/0.9.3/install-clc.lisp 980 +MD5 fa37ba308cbdad5cf330525fd1ebcd28 files/0.9.3/sbcl-gentoo.patch 3810 MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.9.3/sbcl.sh 1512 MD5 653f804ebcd167d167f8163756b7da17 files/0.9.3/sbclrc 639 -MD5 3869dca83085d07e01386eda00c05943 files/0.9.3/install-clc.lisp 980 -MD5 683427165f7d0717333bbb9762972b8d files/0.9.3/customize-target-features.lisp-prefix 95 -MD5 a525c50480694091f6a6688c1472ab10 files/0.9.3/README.Gentoo 1060 ------BEGIN PGP SIGNATURE----- -Version: GnuPG v1.4.1-ecc0.1.6 (GNU/Linux) - -iD8DBQFDMZclKRy60XGEcJIRAkkKAJ9RAITNNeTS8j6EIeBfaD3dUj3rzQCfaPpO -8sAxYeilABFhxRhP6ZbJnk0= -=yPU+ ------END PGP SIGNATURE----- +MD5 da8c0ba7c4f5f9e9924953290d266070 files/0.9.4/README.Gentoo 1060 +MD5 683427165f7d0717333bbb9762972b8d files/0.9.4/customize-target-features.lisp-prefix 95 +MD5 7b753c4f6f63f1fc8630f3c9100a8ca9 files/0.9.4/customize-target-features.lisp-suffix 8 +MD5 3869dca83085d07e01386eda00c05943 files/0.9.4/install-clc.lisp 980 +MD5 5adaa789503e3fecd45ee5724d33584c files/0.9.4/sbcl-gentoo.patch 3810 +MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.9.4/sbcl.sh 1512 +MD5 653f804ebcd167d167f8163756b7da17 files/0.9.4/sbclrc 639 +MD5 b1ce605212de746c2e17816063f71c94 files/0.9.5/README.Gentoo 1162 +MD5 683427165f7d0717333bbb9762972b8d files/0.9.5/customize-target-features.lisp-prefix 95 +MD5 7b753c4f6f63f1fc8630f3c9100a8ca9 files/0.9.5/customize-target-features.lisp-suffix 8 +MD5 3869dca83085d07e01386eda00c05943 files/0.9.5/install-clc.lisp 980 +MD5 e8f8a90582dfbb836ad05cad8e7057b8 files/0.9.5/sbcl-gentoo.patch 3083 +MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.9.5/sbcl.sh 1512 +MD5 653f804ebcd167d167f8163756b7da17 files/0.9.5/sbclrc 639 +MD5 41c44af5374afae0f627457c2406ce35 files/digest-sbcl-0.9.3 557 +MD5 d118e40afe2da4c015ff893db4ae12c3 files/digest-sbcl-0.9.4 557 +MD5 efdcf96290cd16a3a436dd593ea78e88 files/digest-sbcl-0.9.5 557 +MD5 276b2c3efa0ff299306d94ad4704a9e2 metadata.xml 1004 +MD5 4b4f52ef8ceb0eb77b6976520c78f719 sbcl-0.9.3.ebuild 5046 +MD5 845ba0e216f2adf5eb504a5eb06b9037 sbcl-0.9.4.ebuild 5046 +MD5 0e6b8872b9548155d9b781e71def7ed6 sbcl-0.9.5.ebuild 5049 diff --git a/dev-lisp/sbcl/files/0.9.5/README.Gentoo b/dev-lisp/sbcl/files/0.9.5/README.Gentoo new file mode 100644 index 000000000000..33631930e228 --- /dev/null +++ b/dev-lisp/sbcl/files/0.9.5/README.Gentoo @@ -0,0 +1,30 @@ +-*- outline -*- $Id: README.Gentoo,v 1.1 2005/10/23 19:46:25 mkennedy Exp $ + +Gentoo GNU/Linux specific notes for SBCL +---------------------------------------- + +This is the README.Gentoo file from /usr/share/doc/@PF@/ directory. + + * The Gentoo port uses patches from the Debian project's SBCL port. + + * An SBCL with support for multi-threading on GNU/Linux for the x86 and amd64 + platforms is available with 'USE="threads" emerge dev-lisp/sbcl'. Note, an + NPTL-enabled GLIBC is a requirement beginning with SBCL 0.9.5. + + * asdf-install is installed as sbcl-asdf-install (the man-page is similarly + named). + + * Support for the Common Lisp Controller is available. + + * If "nosource" is in your USE flags, then SBCL's source will not be installed + (in /usr/lib/sbcl/src). + + * If "unicode" is in your USE flags, then support for SBCL + Unicode will be included. + + * If "ldb" is in your USE flags, then support for the SBCL low-level debugger + will be included. + +If you encounter any problems or have suggestions, use http://bugs.gentoo.org. +Please don't bother the upstream authors unless you are absolutely certain it is +not Gentoo-related. diff --git a/dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-prefix b/dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-prefix new file mode 100644 index 000000000000..40f9a4fc85fa --- /dev/null +++ b/dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-prefix @@ -0,0 +1,5 @@ +(lambda (list) +(flet ((enable (x) +(pushnew x list)) +(disable (x) +(setf list (remove x list)))) diff --git a/dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-suffix b/dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-suffix new file mode 100644 index 000000000000..dbbde7adc44e --- /dev/null +++ b/dev-lisp/sbcl/files/0.9.5/customize-target-features.lisp-suffix @@ -0,0 +1,2 @@ +) +list) diff --git a/dev-lisp/sbcl/files/0.9.5/install-clc.lisp b/dev-lisp/sbcl/files/0.9.5/install-clc.lisp new file mode 100644 index 000000000000..c8e0a93a729f --- /dev/null +++ b/dev-lisp/sbcl/files/0.9.5/install-clc.lisp @@ -0,0 +1,34 @@ +;;; -*- Mode: LISP; Package: CL-USER -*- +;;; +;;; Copyright (C) Peter Van Eynde 2001 and Kevin Rosenberg 2002-2003 +;;; +;;; License: LGPL v2 +;;; +(in-package "COMMON-LISP-USER") + +(handler-case + (load "/usr/share/common-lisp/source/common-lisp-controller/common-lisp-controller.lisp") + (error (e) + (format t "~%Error during load of common-lisp-controller.lisp: ~A~%" e) + (sb-unix:unix-exit 1))) + +(handler-case + (common-lisp-controller:init-common-lisp-controller-v4 "sbcl") + (error (e) + (format t "~%Error running init-common-lisp-controller-v4: ~A~%" e) + (sb-unix:unix-exit 1))) + +(when (probe-file #p"/etc/lisp.config") + (load #p"/etc/lisp.config")) + +(setf (logical-pathname-translations "SYS") + '(("SYS:SRC;**;*.*.*" + #P"/usr/share/sbcl/src/**/*.*") + ("SYS:CONTRIB;**;*.*.*" + #P"/usr/share/sbcl/**/*.*"))) + +(ignore-errors + (format t "~%Saving to sbcl-new.core...") + (sb-ext:gc :full t) + (sb-ext:save-lisp-and-die "sbcl-new.core" + :purify t)) diff --git a/dev-lisp/sbcl/files/0.9.5/sbcl-gentoo.patch b/dev-lisp/sbcl/files/0.9.5/sbcl-gentoo.patch new file mode 100644 index 000000000000..adb5d40d479d --- /dev/null +++ b/dev-lisp/sbcl/files/0.9.5/sbcl-gentoo.patch @@ -0,0 +1,70 @@ +diff -ur sbcl-0.9.5.orig/contrib/sb-bsd-sockets/sb-bsd-sockets.asd sbcl-0.9.5/contrib/sb-bsd-sockets/sb-bsd-sockets.asd +--- sbcl-0.9.5.orig/contrib/sb-bsd-sockets/sb-bsd-sockets.asd 2004-08-02 06:42:56.000000000 -0500 ++++ sbcl-0.9.5/contrib/sb-bsd-sockets/sb-bsd-sockets.asd 2005-09-28 12:34:17.000000000 -0500 +@@ -102,15 +102,3 @@ + + (defmethod perform :after ((o load-op) (c (eql (find-system :sb-bsd-sockets)))) + (provide 'sb-bsd-sockets)) +- +-(defmethod perform ((o test-op) (c (eql (find-system :sb-bsd-sockets)))) +- (operate 'load-op 'sb-bsd-sockets-tests) +- (operate 'test-op 'sb-bsd-sockets-tests)) +- +-(defsystem sb-bsd-sockets-tests +- :depends-on (sb-rt sb-bsd-sockets sb-posix) +- :components ((:file "tests"))) +- +-(defmethod perform ((o test-op) (c (eql (find-system :sb-bsd-sockets-tests)))) +- (or (funcall (intern "DO-TESTS" (find-package "SB-RT"))) +- (error "test-op failed"))) +Only in sbcl-0.9.5/contrib/sb-bsd-sockets: sb-bsd-sockets.asd.~1.22.~ +diff -ur sbcl-0.9.5.orig/contrib/sb-posix/sb-posix.asd sbcl-0.9.5/contrib/sb-posix/sb-posix.asd +--- sbcl-0.9.5.orig/contrib/sb-posix/sb-posix.asd 2004-08-04 05:54:18.000000000 -0500 ++++ sbcl-0.9.5/contrib/sb-posix/sb-posix.asd 2005-09-28 12:35:34.000000000 -0500 +@@ -88,33 +88,5 @@ + :package :sb-posix :depends-on ("defpackage")) + (:file "interface" :depends-on ("constants" "macros" "designator" "alien")))) + +-(defsystem sb-posix-tests +- :depends-on (sb-rt) +- :components ((:file "posix-tests"))) +- + (defmethod perform :after ((o load-op) (c (eql (find-system :sb-posix)))) + (provide 'sb-posix)) +- +-(defmethod perform ((o test-op) (c (eql (find-system :sb-posix)))) +- (operate 'load-op 'sb-posix-tests) +- (operate 'test-op 'sb-posix-tests)) +- +-(defmethod perform ((o test-op) (c (eql (find-system :sb-posix-tests)))) +- (funcall (intern "DO-TESTS" (find-package "SB-RT"))) +- (let ((failures (funcall (intern "PENDING-TESTS" "SB-RT"))) +- (ignored-failures (loop for sym being the symbols of :sb-posix-tests +- if (search ".ERROR" (symbol-name sym)) +- collect sym))) +- (cond +- ((null failures) +- t) +- ((null (set-difference failures ignored-failures)) +- (warn "~@<some POSIX implementations return incorrect error values for ~ +- failing calls, but there is legitimate variation between ~ +- implementations too. If you think the errno ~ +- from your platform is valid, please contact the sbcl ~ +- developers; otherwise, please submit a bug report to your ~ +- kernel distributor~@:>") +- t) +- (t +- (error "non-errno tests failed!"))))) +Only in sbcl-0.9.5/contrib/sb-posix: sb-posix.asd.~1.11.~ +diff -ur sbcl-0.9.5.orig/src/runtime/runtime.c sbcl-0.9.5/src/runtime/runtime.c +--- sbcl-0.9.5.orig/src/runtime/runtime.c 2005-09-21 10:01:15.000000000 -0500 ++++ sbcl-0.9.5/src/runtime/runtime.c 2005-09-28 16:33:46.000000000 -0500 +@@ -62,7 +62,7 @@ + #endif + + #ifndef SBCL_HOME +-#define SBCL_HOME "/usr/local/lib/sbcl/" ++#define SBCL_HOME "/usr/lib/sbcl/" + #endif + + diff --git a/dev-lisp/sbcl/files/0.9.5/sbcl.sh b/dev-lisp/sbcl/files/0.9.5/sbcl.sh new file mode 100644 index 000000000000..66253874d2a3 --- /dev/null +++ b/dev-lisp/sbcl/files/0.9.5/sbcl.sh @@ -0,0 +1,60 @@ +#!/bin/sh + +if [ ! -f /usr/share/common-lisp/source/common-lisp-controller/common-lisp-controller.lisp ] ; then + cat <<EOF +$0: cannot find the common-lisp-controller source. +EOF + exit 0 +fi + +build_error() +{ + echo "Build failure $1" + exit 1 +} + +case $1 in + install-clc) + echo $0 loading and dumping clc. + ( cd /usr/lib/sbcl + /usr/bin/sbcl --core /usr/lib/sbcl/sbcl-dist.core \ + --noinform --sysinit /etc/sbclrc --userinit /dev/null \ + --load "/usr/lib/sbcl/install-clc.lisp" 2> /dev/null + mv sbcl-new.core sbcl.core || (echo FAILED ; cp sbcl-dist.core sbcl.core ) ) + ;; + remove-clc) + echo $0 removing clc-enabled image + cp /usr/lib/sbcl/sbcl-dist.core /usr/lib/sbcl/sbcl.core + ;; + rebuild) + echo $0 rebuilding... + shift + echo rebuilding $1 + /usr/bin/sbcl --noinform --sysinit /etc/sbclrc --userinit /dev/null \ + --disable-debugger \ + --eval \ +"(handler-case + (progn + (asdf:operate 'asdf:compile-op (quote $1)) + (sb-unix:unix-exit 0)) + (error (e) + (ignore-errors (format t \"~&Build error: ~A~%\" e)) + (finish-output) + (sb-unix:unix-exit 1)))" || build_error + ;; + remove) + echo $0 removing packages... + shift + while [ ! -z "$1" ] ; do + rm -rf "/var/cache/common-lisp-controller/*/sbcl/${1}" + shift + done + ;; + *) + echo $0 unkown command $1 + echo known commands: rebuild, remove, install-clc, and remove-clc + exit 1 + ;; +esac + +exit 0 diff --git a/dev-lisp/sbcl/files/0.9.5/sbclrc b/dev-lisp/sbcl/files/0.9.5/sbclrc new file mode 100644 index 000000000000..91f31720d896 --- /dev/null +++ b/dev-lisp/sbcl/files/0.9.5/sbclrc @@ -0,0 +1,18 @@ +;;; -*- Mode: Lisp; Syntax: ANSI-Common-Lisp; Package: CL-USER -*- + +;;; This file is installed as /etc/sbcl.rc and run on every invocation +;;; of SBCL + +(if (probe-file "/etc/lisp-config.lisp") + (load "/etc/lisp-config.lisp") + (format t "~%;;; Warning: there is no /etc/lisp-config.lisp file")) + +;;; The following is required if you want source location functions to +;;; work (such as those called when you use M-. (edit definition) in +;;; ILISP or SLIME) + +(setf (logical-pathname-translations "SYS") + '(("SYS:SRC;**;*.*.*" #p"/usr/lib/sbcl/src/**/*.*") + ("SYS:CONTRIB;**;*.*.*" #p"/usr/lib/sbcl/**/*.*"))) + +;;; sbclrc ends here diff --git a/dev-lisp/sbcl/files/digest-sbcl-0.9.5 b/dev-lisp/sbcl/files/digest-sbcl-0.9.5 new file mode 100644 index 000000000000..89cd4fc032f7 --- /dev/null +++ b/dev-lisp/sbcl/files/digest-sbcl-0.9.5 @@ -0,0 +1,7 @@ +MD5 29ad145f1fc45c65b8d65b39013bc43f sbcl-0.7.10-mips-linux-binary.tar.gz 7473873 +MD5 6c193e328cdb472787ef78401ee5294c sbcl-0.8.1-x86-linux-binary.tar.bz2 6348098 +MD5 3a72d0785ce0a8e02f9af632c2a4f217 sbcl-0.8.15-powerpc-linux-binary.tar.bz2 6656148 +MD5 029b85186984d0bfc8b49c4de1e8e45e sbcl-0.8.15-sparc-linux-binary.tar.bz2 6903090 +MD5 beba4861dc8de0a2420c483f15a93c05 sbcl-0.8.19-x86-64-linux-binary.tar.bz2 7466117 +MD5 7b768d3299248be8f41fa856fa335b81 sbcl-0.9.5-html.tar.bz2 117514 +MD5 f594f18813c08f262a6df9a36288adcb sbcl-0.9.5-source.tar.bz2 2658381 diff --git a/dev-lisp/sbcl/metadata.xml b/dev-lisp/sbcl/metadata.xml index d806d206463b..30c56e35da50 100644 --- a/dev-lisp/sbcl/metadata.xml +++ b/dev-lisp/sbcl/metadata.xml @@ -3,22 +3,19 @@ <pkgmetadata> <herd>common-lisp</herd> <longdescription> -Steel Bank Common Lisp is an open source Common Lisp -implementation. It provides an integrated native compiler, -interpreter, and debugger. +Steel Bank Common Lisp is an open source Common Lisp implementation. It +provides an integrated native compiler, interpreter, and debugger. -SBCL is a fork off of the main branch of CMUCL. SBCL is distinguished -from CMUCL by a greater emphasis on maintainability. In particular, -the SBCL system can be built directly from its source code, so that -the output corresponds to the source code in a controlled, verifiable -way, and arbitrary changes can be made to the system without causing -bootstrapping problems. SBCL also places less emphasis than CMU CL -does on new non-ANSI extensions, or on backward compatibility with old -non-ANSI features. +SBCL is a fork off of the main branch of CMUCL. SBCL is distinguished from +CMUCL by a greater emphasis on maintainability. In particular, the SBCL system +can be built directly from its source code, so that the output corresponds to +the source code in a controlled, verifiable way, and arbitrary changes can be +made to the system without causing bootstrapping problems. SBCL also places +less emphasis than CMU CL does on new non-ANSI extensions, or on backward +compatibility with old non-ANSI features. -Support for native threading on GNU/Linux is available for the x86 -platform, including support for the new futex system call available in -2.6.x kernels. +Support for native threading on GNU/Linux is available for the x86 and amd64 +platforms using an NPTL enabled GLIBC. SBCL 0.8.17 and later support Unicode. </longdescription> diff --git a/dev-lisp/sbcl/sbcl-0.9.5.ebuild b/dev-lisp/sbcl/sbcl-0.9.5.ebuild new file mode 100644 index 000000000000..12a57afc1768 --- /dev/null +++ b/dev-lisp/sbcl/sbcl-0.9.5.ebuild @@ -0,0 +1,172 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/sbcl-0.9.5.ebuild,v 1.1 2005/10/23 19:46:25 mkennedy Exp $ + +inherit common-lisp-common-2 eutils + +BV_X86=0.8.1 +BV_PPC=0.8.15 +BV_SPARC=0.8.15 +BV_MIPS=0.7.10 +BV_AMD64=0.8.19 + +DESCRIPTION="Steel Bank Common Lisp (SBCL) is an implementation of ANSI Common Lisp." +HOMEPAGE="http://sbcl.sourceforge.net/" +SRC_URI="mirror://sourceforge/sbcl/${P}-source.tar.bz2 + mirror://sourceforge/sbcl/${P}-html.tar.bz2 + x86? ( mirror://sourceforge/sbcl/${PN}-${BV_X86}-x86-linux-binary.tar.bz2 ) + ppc? ( mirror://sourceforge/sbcl/${PN}-${BV_PPC}-powerpc-linux-binary.tar.bz2 ) + sparc? ( mirror://sourceforge/sbcl/${PN}-${BV_SPARC}-sparc-linux-binary.tar.bz2 ) + mips? ( mirror://sourceforge/sbcl/${PN}-${BV_MIPS}-mips-linux-binary.tar.gz ) + amd64? ( mirror://sourceforge/sbcl/${PN}-${BV_AMD64}-x86-64-linux-binary.tar.bz2 )" + +LICENSE="MIT" +SLOT="0" + +KEYWORDS="~x86 ~ppc ~sparc ~mips ~amd64" +IUSE="hardened ldb nosource threads unicode" + +DEPEND="=dev-lisp/common-lisp-controller-4* + >=dev-lisp/cl-asdf-1.84 + sys-apps/texinfo" + +PROVIDE="virtual/commonlisp" + +MY_WORK=${S}/my_work + +pkg_setup() { + if use hardened && gcc-config -c |grep -qv vanilla; then + while read line; do einfo "${line}"; done <<'EOF' + +So-called "hardened" compiler features are incompatible with SBCL. You +must use gcc-config to select a profile with non-hardened features +(the "vanilla" profile) and "source /etc/profile" before continuing. + +EOF + die + fi + + # FIXME Maybe something should be done in the case where a user requests + # threads on a non-NPTL system +} + +src_unpack() { + mkdir -p ${MY_WORK} && cp ${FILESDIR}/${PV}/* ${MY_WORK} + sed -i "s,/usr/lib,/usr/$(get_libdir),g" ${MY_WORK}/* + + if use x86; then + unpack ${PN}-${BV_X86}-x86-linux-binary.tar.bz2 + mv ${PN}-${BV_X86} x86-binary + elif use ppc; then + unpack ${PN}-${BV_PPC}-powerpc-linux-binary.tar.bz2 + mv ${PN}-${BV_PPC}-powerpc-linux ppc-binary + elif use sparc; then + unpack ${PN}-${BV_SPARC}-sparc-linux-binary.tar.bz2 + mv ${PN}-${BV_SPARC}-sparc-linux sparc-binary || die + elif use mips; then + unpack ${PN}-${BV_MIPS}-mips-linux-binary.tar.gz + mv ${PN}-${BV_MIPS}-mips-linux mips-binary + elif use amd64; then + unpack ${PN}-${BV_AMD64}-x86-64-linux-binary.tar.bz2 + mv ${PN}-${BV_AMD64}-x86-64-linux x86-64-binary + fi + + unpack ${P}-source.tar.bz2 + epatch ${MY_WORK}/sbcl-gentoo.patch || die + sed -i "s,/lib,/$(get_libdir),g" ${S}/install.sh + + cp ${MY_WORK}/customize-target-features.lisp-prefix \ + ${S}/customize-target-features.lisp + if use x86 || use amd64; then + use threads && echo '(enable :sb-thread)' \ + >>${S}/customize-target-features.lisp + fi + use ldb \ + && echo '(enable :sb-ldb)' \ + >>${S}/customize-target-features.lisp +# use x86 \ +# && echo '(enable :sb-futex)' \ +# >>${S}/customize-target-features.lisp + echo '(disable :sb-test)' >>${S}/customize-target-features.lisp + ! use unicode \ + && echo '(disable :sb-unicode)' \ + >>${S}/customize-target-features.lisp + cat ${MY_WORK}/customize-target-features.lisp-suffix \ + >>${S}/customize-target-features.lisp + find ${S} -type f -name .cvsignore -exec rm -f '{}' \; + find ${S} -depth -type d -name CVS -exec rm -rf '{}' \; + find ${S} -type f -name \*.c -exec chmod 644 '{}' \; +} + +src_compile() { + local bindir="" + + if use x86; then + bindir=../x86-binary + elif use ppc; then + bindir=../ppc-binary + elif use sparc; then + bindir=../sparc-binary + elif use mips; then + bindir=../mips-binary + elif use amd64; then + bindir=../x86-64-binary + fi + + LANG=C PATH=${bindir}/src/runtime:${PATH} SBCL_HOME=${bindir}/output GNUMAKE=make \ + ./make.sh 'sbcl + --sysinit /dev/null + --userinit /dev/null + --disable-debugger + --core ${bindir}/output/sbcl.core' \ + || die + cd ${S}/doc/manual + LANG=C make info html || die +} + +src_install() { + unset SBCL_HOME + + insinto /etc/ + doins ${MY_WORK}/sbclrc # Gentoo specific (from Debian) + + exeinto /usr/$(get_libdir)/common-lisp/bin + doexe ${MY_WORK}/sbcl.sh # Gentoo specific (from Debian) + + dodir /usr/share/man + dodir /usr/share/doc/${PF} + INSTALL_ROOT=${D}/usr DOC_DIR=${D}/usr/share/doc/${PF} sh install.sh || die + mv ${D}/usr/$(get_libdir)/sbcl/sbcl.core ${D}/usr/$(get_libdir)/sbcl/sbcl-dist.core || die + + insinto /usr/$(get_libdir)/sbcl + doins ${MY_WORK}/install-clc.lisp # Gentoo specific (from Debian) + + doman doc/sbcl-asdf-install.1 + + dodoc BUGS COPYING CREDITS INSTALL NEWS OPTIMIZATIONS PRINCIPLES README STYLE SUPPORT TLA TODO + dodoc ${MY_WORK}/README.Gentoo + dohtml doc/html/* + + doinfo ${S}/doc/manual/*.info + + keepdir /usr/$(get_libdir)/common-lisp/sbcl + + if ! use nosource; then + # install the SBCL source + find ${S}/src -type f -name \*.fasl |xargs rm -f + mv ${S}/src ${D}/usr/$(get_libdir)/sbcl/ + fi + + impl-save-timestamp-hack sbcl || die +} + +pkg_postinst() { + LANG=C standard-impl-postinst sbcl +} + +pkg_postrm() { + LANG=C standard-impl-postrm sbcl /usr/bin/sbcl + if [ ! -x /usr/bin/sbcl ]; then + rm -rf /usr/$(get_libdir)/sbcl/ || die + fi +} |