diff options
author | Matthew Kennedy <mkennedy@gentoo.org> | 2005-04-07 03:01:00 +0000 |
---|---|---|
committer | Matthew Kennedy <mkennedy@gentoo.org> | 2005-04-07 03:01:00 +0000 |
commit | 351c67710c6bd9faea468354ca6db8c86557e066 (patch) | |
tree | 0082c08d89ea3c5a49f480b52f6e59f57dce7b17 /dev-lisp/sbcl | |
parent | version bump (diff) | |
download | historical-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/ChangeLog | 5 | ||||
-rw-r--r-- | dev-lisp/sbcl/Manifest | 14 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.20/README.Gentoo | 7 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/README.Gentoo | 44 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/customize-target-features.lisp-prefix | 5 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/customize-target-features.lisp-suffix | 2 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/install-clc.lisp | 34 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/sbcl-gentoo.patch | 32 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/sbcl-no-tests-gentoo.patch | 56 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/sbcl.sh | 60 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/0.8.21/sbclrc | 18 | ||||
-rw-r--r-- | dev-lisp/sbcl/files/digest-sbcl-0.8.21 | 3 | ||||
-rw-r--r-- | dev-lisp/sbcl/sbcl-0.8.21.ebuild | 182 |
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 +} |