summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthew Kennedy <mkennedy@gentoo.org>2005-04-07 03:01:00 +0000
committerMatthew Kennedy <mkennedy@gentoo.org>2005-04-07 03:01:00 +0000
commit351c67710c6bd9faea468354ca6db8c86557e066 (patch)
tree0082c08d89ea3c5a49f480b52f6e59f57dce7b17 /dev-lisp/sbcl
parentversion bump (diff)
downloadhistorical-351c67710c6bd9faea468354ca6db8c86557e066.tar.gz
historical-351c67710c6bd9faea468354ca6db8c86557e066.tar.bz2
historical-351c67710c6bd9faea468354ca6db8c86557e066.zip
Package-Manager: portage-2.0.51.19
Diffstat (limited to 'dev-lisp/sbcl')
-rw-r--r--dev-lisp/sbcl/ChangeLog5
-rw-r--r--dev-lisp/sbcl/Manifest14
-rw-r--r--dev-lisp/sbcl/files/0.8.20/README.Gentoo7
-rw-r--r--dev-lisp/sbcl/files/0.8.21/README.Gentoo44
-rw-r--r--dev-lisp/sbcl/files/0.8.21/customize-target-features.lisp-prefix5
-rw-r--r--dev-lisp/sbcl/files/0.8.21/customize-target-features.lisp-suffix2
-rw-r--r--dev-lisp/sbcl/files/0.8.21/install-clc.lisp34
-rw-r--r--dev-lisp/sbcl/files/0.8.21/sbcl-gentoo.patch32
-rw-r--r--dev-lisp/sbcl/files/0.8.21/sbcl-no-tests-gentoo.patch56
-rw-r--r--dev-lisp/sbcl/files/0.8.21/sbcl.sh60
-rw-r--r--dev-lisp/sbcl/files/0.8.21/sbclrc18
-rw-r--r--dev-lisp/sbcl/files/digest-sbcl-0.8.213
-rw-r--r--dev-lisp/sbcl/sbcl-0.8.21.ebuild182
13 files changed, 458 insertions, 4 deletions
diff --git a/dev-lisp/sbcl/ChangeLog b/dev-lisp/sbcl/ChangeLog
index b43ac02832e8..212a7fbd4094 100644
--- a/dev-lisp/sbcl/ChangeLog
+++ b/dev-lisp/sbcl/ChangeLog
@@ -1,6 +1,9 @@
# 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.57 2005/03/16 07:36:15 mkennedy Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/ChangeLog,v 1.58 2005/04/07 03:01:00 mkennedy Exp $
+
+ 07 Apr 2005; Matthew Kennedy <mkennedy@gentoo.org> :
+ New upstream version.
16 Mar 2005; Matthew Kennedy <mkennedy@gentoo.org> sbcl-0.8.18.ebuild,
sbcl-0.8.19.ebuild, sbcl-0.8.20.ebuild:
diff --git a/dev-lisp/sbcl/Manifest b/dev-lisp/sbcl/Manifest
index 7dabebd457df..a3ebc3475502 100644
--- a/dev-lisp/sbcl/Manifest
+++ b/dev-lisp/sbcl/Manifest
@@ -1,4 +1,4 @@
-MD5 e73523d89e078548bca3f85b1ddf7edb ChangeLog 16587
+MD5 484a5d56f7c6bcdfeb7e466f9948a640 ChangeLog 16667
MD5 0c9bf11185a2a2f1916fc3dc72c0e89e metadata.xml 1037
MD5 171a2860c8099c791c1a5d09a6de79d9 sbcl-0.8.14.ebuild 3882
MD5 99471881a4600b3754568cf9a57da836 sbcl-0.8.15.ebuild 3941
@@ -6,13 +6,15 @@ MD5 b1dc94cfc64e3f6a12ca8ddf43d87eb5 sbcl-0.8.16.ebuild 3940
MD5 f44918ca491764cc17b42a6ab71e249d sbcl-0.8.18.ebuild 4127
MD5 e1e082cd279eba46322bafddfe664760 sbcl-0.8.19.ebuild 4179
MD5 acd60c99719cf076ba9d3300f89243f6 sbcl-0.8.20.ebuild 5416
+MD5 4442b0e3a70d72ceb4576232673570ad sbcl-0.8.21.ebuild 5416
MD5 c79912580313a9a43b0b9fd2aa794ba2 files/digest-sbcl-0.8.14 468
MD5 74f94f11c31e6e9395b26994ebc70aa7 files/digest-sbcl-0.8.15 469
MD5 a3c050d853b5f0484425c9e35fce226f files/digest-sbcl-0.8.16 469
MD5 917041583d96efd479e31e2f3d84e71f files/digest-sbcl-0.8.18 469
MD5 910f47ccbe38fb0a5f5e396c708ec60c files/digest-sbcl-0.8.19 469
MD5 512426af57bd3f80459b5e4994072c0f files/digest-sbcl-0.8.20 620
-MD5 f7a86e447847337879c35d62270eecf5 files/0.8.20/README.Gentoo 1525
+MD5 ddfaa8790a20f5fdd6cf4c9b62735e84 files/digest-sbcl-0.8.21 221
+MD5 8fbb2dee1025c012114183e5567e05c6 files/0.8.20/README.Gentoo 1602
MD5 683427165f7d0717333bbb9762972b8d files/0.8.20/customize-target-features.lisp-prefix 95
MD5 7b753c4f6f63f1fc8630f3c9100a8ca9 files/0.8.20/customize-target-features.lisp-suffix 8
MD5 3869dca83085d07e01386eda00c05943 files/0.8.20/install-clc.lisp 980
@@ -20,6 +22,14 @@ MD5 5ac3f15468854d17ca28cfe6bf6a41df files/0.8.20/sbcl-gentoo.patch 1172
MD5 b02ec350d248da1c500cb463bd3a3065 files/0.8.20/sbcl-no-tests-gentoo.patch 2609
MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.8.20/sbcl.sh 1512
MD5 653f804ebcd167d167f8163756b7da17 files/0.8.20/sbclrc 639
+MD5 1c8278be8d7669c67d3250e6c41ac929 files/0.8.21/README.Gentoo 1602
+MD5 683427165f7d0717333bbb9762972b8d files/0.8.21/customize-target-features.lisp-prefix 95
+MD5 7b753c4f6f63f1fc8630f3c9100a8ca9 files/0.8.21/customize-target-features.lisp-suffix 8
+MD5 3869dca83085d07e01386eda00c05943 files/0.8.21/install-clc.lisp 980
+MD5 2a2e9f5c84cf4c30cb8cf9910c9b122d files/0.8.21/sbcl-gentoo.patch 1172
+MD5 fc134245ed4a6ec677c07784e618f992 files/0.8.21/sbcl-no-tests-gentoo.patch 2609
+MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.8.21/sbcl.sh 1512
+MD5 653f804ebcd167d167f8163756b7da17 files/0.8.21/sbclrc 639
MD5 95566eb0d55e184e354f8ef05b9425c2 files/0.8.14/README.Gentoo 941
MD5 6f05f494b80fa25732a658deec4133c8 files/0.8.14/customize-target-features.lisp 574
MD5 a0edd1aecd1416792590693e5a6d2cb3 files/0.8.14/customize-target-features.lisp.no-threads 577
diff --git a/dev-lisp/sbcl/files/0.8.20/README.Gentoo b/dev-lisp/sbcl/files/0.8.20/README.Gentoo
index 81381ac8b3f0..2b88b338d257 100644
--- a/dev-lisp/sbcl/files/0.8.20/README.Gentoo
+++ b/dev-lisp/sbcl/files/0.8.20/README.Gentoo
@@ -1,4 +1,4 @@
--*- outline -*- $Id: README.Gentoo,v 1.1 2005/03/03 17:51:36 mkennedy Exp $
+-*- outline -*- $Id: README.Gentoo,v 1.2 2005/04/07 02:58:58 mkennedy Exp $
Gentoo GNU/Linux specific notes for SBCL
----------------------------------------
@@ -34,6 +34,11 @@ This is the README.Gentoo file from /usr/share/doc/@PF@/ directory.
http://article.gmane.org/gmane.lisp.steel-bank.devel/4279
http://article.gmane.org/gmane.lisp.steel-bank.devel/4341
+ Ports which require callbacks in SBCL:
+
+ cl-zeroconf
+ lambda-gtk
+
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.8.21/README.Gentoo b/dev-lisp/sbcl/files/0.8.21/README.Gentoo
new file mode 100644
index 000000000000..3f208bcfbbd1
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/README.Gentoo
@@ -0,0 +1,44 @@
+-*- outline -*- $Id: README.Gentoo,v 1.1 2005/04/07 02:58:58 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 x86 is available
+ with 'USE="threads" emerge dev-lisp/sbcl'
+
+ * 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 "callbacks" is in your USE flags, then support for foreign callbacks will
+ be included. This is useful for libraries such as Lambda-GTK.
+
+ NOTE: callback support is implemented using Thomas Burdick's SBCL-AF patch
+ which is distributed outside of SBCL. This will NOT be the final API SBCL
+ uses. See also:
+
+ http://article.gmane.org/gmane.lisp.steel-bank.devel/4279
+ http://article.gmane.org/gmane.lisp.steel-bank.devel/4341
+
+ Ports which require callbacks in SBCL:
+
+ cl-zeroconf
+ lambda-gtk
+
+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.8.21/customize-target-features.lisp-prefix b/dev-lisp/sbcl/files/0.8.21/customize-target-features.lisp-prefix
new file mode 100644
index 000000000000..40f9a4fc85fa
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/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.8.21/customize-target-features.lisp-suffix b/dev-lisp/sbcl/files/0.8.21/customize-target-features.lisp-suffix
new file mode 100644
index 000000000000..dbbde7adc44e
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/customize-target-features.lisp-suffix
@@ -0,0 +1,2 @@
+)
+list)
diff --git a/dev-lisp/sbcl/files/0.8.21/install-clc.lisp b/dev-lisp/sbcl/files/0.8.21/install-clc.lisp
new file mode 100644
index 000000000000..c8e0a93a729f
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/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.8.21/sbcl-gentoo.patch b/dev-lisp/sbcl/files/0.8.21/sbcl-gentoo.patch
new file mode 100644
index 000000000000..98a9ee85c35f
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/sbcl-gentoo.patch
@@ -0,0 +1,32 @@
+diff -ru sbcl-0.8.21.orig/contrib/sb-posix/posix-tests.lisp sbcl-0.8.21/contrib/sb-posix/posix-tests.lisp
+--- sbcl-0.8.21.orig/contrib/sb-posix/posix-tests.lisp 2004-03-15 09:24:53.000000000 -0600
++++ sbcl-0.8.21/contrib/sb-posix/posix-tests.lisp 2004-04-28 14:47:50.179460512 -0500
+@@ -96,7 +96,7 @@
+ (sb-posix:syscall-errno c)))
+ #.sb-posix::eexist)
+
+-(deftest mkdir.error.2
++#+nil (deftest mkdir.error.2
+ (handler-case
+ (sb-posix:mkdir "/" 0)
+ (sb-posix:syscall-error (c)
+@@ -149,7 +149,7 @@
+ (sb-posix:syscall-errno c)))
+ #.sb-posix::enotdir)
+
+-(deftest rmdir.error.3
++#+nil (deftest rmdir.error.3
+ (handler-case
+ (sb-posix:rmdir "/")
+ (sb-posix:syscall-error (c)
+diff -ru sbcl-0.8.21.orig/src/runtime/GNUmakefile sbcl-0.8.21/src/runtime/GNUmakefile
+--- sbcl-0.8.21.orig/src/runtime/GNUmakefile 2004-04-10 08:37:23.000000000 -0500
++++ sbcl-0.8.21/src/runtime/GNUmakefile 2004-04-28 14:46:29.556717032 -0500
+@@ -33,6 +33,7 @@
+ # symlink to Config-foo.
+ include Config
+
++CFLAGS += -DSBCL_HOME='"/usr/lib/sbcl"'
+
+ C_SRCS = alloc.c backtrace.c breakpoint.c coreparse.c \
+ dynbind.c gc-common.c globals.c interr.c interrupt.c \
diff --git a/dev-lisp/sbcl/files/0.8.21/sbcl-no-tests-gentoo.patch b/dev-lisp/sbcl/files/0.8.21/sbcl-no-tests-gentoo.patch
new file mode 100644
index 000000000000..bf34ce4ad328
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/sbcl-no-tests-gentoo.patch
@@ -0,0 +1,56 @@
+diff -ur sbcl-0.8.21.orig/contrib/sb-bsd-sockets/sb-bsd-sockets.asd sbcl-0.8.21/contrib/sb-bsd-sockets/sb-bsd-sockets.asd
+--- sbcl-0.8.21.orig/contrib/sb-bsd-sockets/sb-bsd-sockets.asd 2004-02-11 05:00:40.000000000 -0600
++++ sbcl-0.8.21/contrib/sb-bsd-sockets/sb-bsd-sockets.asd 2004-07-11 15:30:52.230966464 -0500
+@@ -103,14 +103,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")))
+diff -ur sbcl-0.8.21.orig/contrib/sb-posix/sb-posix.asd sbcl-0.8.21/contrib/sb-posix/sb-posix.asd
+--- sbcl-0.8.21.orig/contrib/sb-posix/sb-posix.asd 2003-11-29 14:41:47.000000000 -0600
++++ sbcl-0.8.21/contrib/sb-posix/sb-posix.asd 2004-07-11 15:52:38.766342896 -0500
+@@ -86,34 +86,3 @@
+ "constants"
+ :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!")))))
diff --git a/dev-lisp/sbcl/files/0.8.21/sbcl.sh b/dev-lisp/sbcl/files/0.8.21/sbcl.sh
new file mode 100644
index 000000000000..66253874d2a3
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/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.8.21/sbclrc b/dev-lisp/sbcl/files/0.8.21/sbclrc
new file mode 100644
index 000000000000..91f31720d896
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.8.21/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.8.21 b/dev-lisp/sbcl/files/digest-sbcl-0.8.21
new file mode 100644
index 000000000000..e753fa895876
--- /dev/null
+++ b/dev-lisp/sbcl/files/digest-sbcl-0.8.21
@@ -0,0 +1,3 @@
+MD5 61a7e7c3c6be55e3155a901e67ff987a sbcl-0.8.21-source.tar.bz2 2448354
+MD5 a2e4c0e99428a16524669798bf479b14 sbcl-0.8.21-html.tar.bz2 12496
+MD5 6c193e328cdb472787ef78401ee5294c sbcl-0.8.1-x86-linux-binary.tar.bz2 6348098
diff --git a/dev-lisp/sbcl/sbcl-0.8.21.ebuild b/dev-lisp/sbcl/sbcl-0.8.21.ebuild
new file mode 100644
index 000000000000..0ee603615518
--- /dev/null
+++ b/dev-lisp/sbcl/sbcl-0.8.21.ebuild
@@ -0,0 +1,182 @@
+# 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.8.21.ebuild,v 1.1 2005/04/07 02:58:58 mkennedy Exp $
+
+inherit common-lisp-common-2 eutils
+
+SBCL_AF_PV=2004-10-22
+
+BV_X86=0.8.1
+BV_PPC=0.8.8
+BV_SPARC=0.7.13
+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}-ppc-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 )
+ callbacks? ( http://pinhead.music.uiuc.edu/~hkt/sbcl-af-${SBCL_AF_PV}.tgz )"
+
+LICENSE="MIT"
+SLOT="0"
+
+KEYWORDS="~x86 ~ppc ~sparc ~mips ~amd64"
+IUSE="threads doc nosource unicode ldb callbacks"
+
+DEPEND="=dev-lisp/common-lisp-controller-4*
+ >=dev-lisp/cl-asdf-1.84
+ sys-apps/texinfo
+ doc? ( virtual/tetex )"
+
+PROVIDE="virtual/commonlisp"
+
+pkg_setup() {
+ if use hardened; then
+ die 'So-called "hardened" USE features are incompatible with SBCL.'
+ fi
+}
+
+src_unpack() {
+ 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}-ppc-linux-binary.tar.bz2
+ mv ${PN}-${BV_PPC}-ppc-linux ppc-binary
+ elif use sparc; then
+ unpack ${PN}-${BV_SPARC}-sparc-linux-binary.tar.bz2
+ echo mv ${PN}-${BV_SPARC} sparc-binary || die
+ mv ${PN}-${BV_SPARC} 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 ${FILESDIR}/${PV}/sbcl-gentoo.patch
+ epatch ${FILESDIR}/${PV}/sbcl-no-tests-gentoo.patch
+
+ cp ${FILESDIR}/${PV}/customize-target-features.lisp-prefix \
+ ${S}/customize-target-features.lisp
+ use x86 && use threads \
+ && echo '(enable :sb-thread)' \
+ >>${S}/customize-target-features.lisp
+ 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 ${FILESDIR}/${PV}/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 '{}' \;
+
+ if use callbacks; then
+ einfo "You have specified the \"callbacks\" USE flag. Callbacks may only work for x86."
+ einfo "Please refer to README.Gentoo for more information."
+ unpack sbcl-af-${SBCL_AF_PV}.tgz
+ fi
+}
+
+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
+
+ PATH=${bindir}/src/runtime:${PATH} SBCL_HOME=${bindir}/output GNUMAKE=make \
+ ./make.sh 'sbcl
+ --sysinit /dev/null
+ --userinit /dev/null
+ --no-debugger
+ --core ${bindir}/output/sbcl.core' \
+ || die
+ cd ${S}/doc/manual
+ make info
+ use doc && make ps pdf
+}
+
+src_install() {
+ unset SBCL_HOME
+
+ insinto /etc/
+ doins ${FILESDIR}/${PV}/sbclrc # Gentoo specific (from Debian)
+
+ exeinto /usr/lib/common-lisp/bin
+ doexe ${FILESDIR}/${PV}/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/lib/sbcl/sbcl.core ${D}/usr/lib/sbcl/sbcl-dist.core || die
+
+ insinto /usr/lib/sbcl
+ doins ${FILESDIR}/${PV}/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 ${FILESDIR}/${PV}/README.Gentoo
+ dohtml doc/html/*
+
+ doinfo ${S}/doc/manual/*.info
+ use doc && dodoc ${S}/doc/manual/*.{pdf,ps}
+
+ keepdir /usr/lib/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/lib/sbcl/
+ fi
+
+ impl-save-timestamp-hack sbcl || die
+}
+
+pkg_postinst() {
+ standard-impl-postinst sbcl
+ if use callbacks; then
+ mv /usr/lib/sbcl/sbcl.core /usr/lib/sbcl/sbcl-nocallbacks.core || die
+ pushd ${WORKDIR}/sbcl-af
+ sbcl --core /usr/lib/sbcl/sbcl-nocallbacks.core \
+ --load 'system' \
+ --eval '(sb-ext:save-lisp-and-die "/usr/lib/sbcl/sbcl.core")' || die
+ popd
+ fi
+# Image Summary
+# -------------
+# /usr/lib/sbcl/sbcl-dist.core - Plain SBCL image
+# /usr/lib/sbcl/sbcl-nocallbacks.core - CLC (Common Lisp Controller) image
+# /usr/lib/sbcl/sbcl.core - CLC image w/ callbacks support
+}
+
+pkg_postrm() {
+ standard-impl-postrm sbcl /usr/bin/sbcl
+ if [ ! -x /usr/bin/sbcl ]; then
+ rm -rf /usr/lib/sbcl/ || die
+ fi
+}