summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthew Kennedy <mkennedy@gentoo.org>2006-01-03 18:31:51 +0000
committerMatthew Kennedy <mkennedy@gentoo.org>2006-01-03 18:31:51 +0000
commitf70726420231523c57217277f2cd5474171c6732 (patch)
tree6c31e18fdc09e52b9654dafb1644412816a6b3ed /dev-lisp
parentOOps with Bug #117439 (diff)
downloadhistorical-f70726420231523c57217277f2cd5474171c6732.tar.gz
historical-f70726420231523c57217277f2cd5474171c6732.tar.bz2
historical-f70726420231523c57217277f2cd5474171c6732.zip
New upstream version; Improved multilib support; Corrected typo for FASL removal.
Package-Manager: portage-2.1_pre2
Diffstat (limited to 'dev-lisp')
-rw-r--r--dev-lisp/sbcl/ChangeLog15
-rw-r--r--dev-lisp/sbcl/Manifest19
-rw-r--r--dev-lisp/sbcl/files/0.9.8/README.Gentoo30
-rw-r--r--dev-lisp/sbcl/files/0.9.8/customize-target-features.lisp-prefix5
-rw-r--r--dev-lisp/sbcl/files/0.9.8/customize-target-features.lisp-suffix2
-rw-r--r--dev-lisp/sbcl/files/0.9.8/install-clc.lisp34
-rw-r--r--dev-lisp/sbcl/files/0.9.8/sbcl-gentoo.patch70
-rw-r--r--dev-lisp/sbcl/files/0.9.8/sbcl.sh60
-rw-r--r--dev-lisp/sbcl/files/0.9.8/sbclrc18
-rw-r--r--dev-lisp/sbcl/files/digest-sbcl-0.9.86
-rw-r--r--dev-lisp/sbcl/sbcl-0.9.7.ebuild6
-rw-r--r--dev-lisp/sbcl/sbcl-0.9.8.ebuild153
12 files changed, 408 insertions, 10 deletions
diff --git a/dev-lisp/sbcl/ChangeLog b/dev-lisp/sbcl/ChangeLog
index 792edc73ffcc..04e6b191dbc2 100644
--- a/dev-lisp/sbcl/ChangeLog
+++ b/dev-lisp/sbcl/ChangeLog
@@ -1,6 +1,17 @@
# 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.78 2005/12/21 12:37:46 agriffis Exp $
+# Copyright 2002-2006 Gentoo Foundation; Distributed under the GPL v2
+# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/ChangeLog,v 1.79 2006/01/03 18:31:51 mkennedy Exp $
+
+*sbcl-0.9.8 (03 Jan 2006)
+
+ 03 Jan 2006; Matthew Kennedy <mkennedy@gentoo.org>
+ +files/0.9.8/README.Gentoo,
+ +files/0.9.8/customize-target-features.lisp-suffix, +files/0.9.8/sbcl.sh,
+ +files/0.9.8/customize-target-features.lisp-prefix,
+ +files/0.9.8/install-clc.lisp, +files/0.9.8/sbcl-gentoo.patch,
+ +files/0.9.8/sbclrc, sbcl-0.9.7.ebuild, +sbcl-0.9.8.ebuild:
+ New upstream version; Improved multilib support; Corrected typo for FASL
+ removal.
21 Dec 2005; Aron Griffis <agriffis@gentoo.org> sbcl-0.9.7.ebuild:
Minor changes:
diff --git a/dev-lisp/sbcl/Manifest b/dev-lisp/sbcl/Manifest
index 968d65780abe..cda843db6a3f 100644
--- a/dev-lisp/sbcl/Manifest
+++ b/dev-lisp/sbcl/Manifest
@@ -1,7 +1,7 @@
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
-MD5 978a0b0a2aef49ccc1a8490e95b83989 ChangeLog 24051
+MD5 777039a5a0c3106fcf4834aba407e4f5 ChangeLog 24505
MD5 45c4c194bdc01c92730e2f8ea5bbb2e5 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
@@ -22,17 +22,26 @@ MD5 3869dca83085d07e01386eda00c05943 files/0.9.7/install-clc.lisp 980
MD5 d4b64d31c6062dd3c8e990476c0c9449 files/0.9.7/sbcl-gentoo.patch 3083
MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.9.7/sbcl.sh 1512
MD5 653f804ebcd167d167f8163756b7da17 files/0.9.7/sbclrc 639
+MD5 f9278d54d57ffa6048f5a79d45ee1fb4 files/0.9.8/README.Gentoo 1162
+MD5 683427165f7d0717333bbb9762972b8d files/0.9.8/customize-target-features.lisp-prefix 95
+MD5 7b753c4f6f63f1fc8630f3c9100a8ca9 files/0.9.8/customize-target-features.lisp-suffix 8
+MD5 3869dca83085d07e01386eda00c05943 files/0.9.8/install-clc.lisp 980
+MD5 89a689f76a17245b63fac67ccb0269d5 files/0.9.8/sbcl-gentoo.patch 3083
+MD5 7447a308f36b4ad14626357d8f2c8db6 files/0.9.8/sbcl.sh 1512
+MD5 653f804ebcd167d167f8163756b7da17 files/0.9.8/sbclrc 639
MD5 7e5f4692a0e0debe2743ed6a086d29bb files/digest-sbcl-0.9.3 557
MD5 d118e40afe2da4c015ff893db4ae12c3 files/digest-sbcl-0.9.4 557
MD5 8d3b742820c93636f138545632d127b0 files/digest-sbcl-0.9.7 488
+MD5 b774b3b0ca2dc24e6a65f700120d7936 files/digest-sbcl-0.9.8 488
MD5 276b2c3efa0ff299306d94ad4704a9e2 metadata.xml 1004
MD5 e6a8dc74061cced7fd5fab222e795d5f sbcl-0.9.3.ebuild 5046
MD5 845ba0e216f2adf5eb504a5eb06b9037 sbcl-0.9.4.ebuild 5046
-MD5 6e7d5e90cc0ce831ea0dd037bae88850 sbcl-0.9.7.ebuild 4416
+MD5 6fb2c817d4e75aa34ed25d784d2ce7e5 sbcl-0.9.7.ebuild 4420
+MD5 c9c4df28f12a38357ea80dd49beb813e sbcl-0.9.8.ebuild 4566
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.2 (GNU/Linux)
-iD8DBQFDqe15JrHF4yAQTrARAkdoAKCzNO5GxowRP10Irq1gAMLeDlmAPgCfQNSj
-TSLZImZz31YVfxIVszBDJxw=
-=9Dyb
+iD8DBQFDusMjyiNZaEAZA+ARApHDAJ0XjrFi10AI9cZ9a0dFvrlzPn0UtACaAp4Z
+PAn5nhcxUQUdlRBk0K83cC8=
+=Q0NT
-----END PGP SIGNATURE-----
diff --git a/dev-lisp/sbcl/files/0.9.8/README.Gentoo b/dev-lisp/sbcl/files/0.9.8/README.Gentoo
new file mode 100644
index 000000000000..80b69316c90c
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.9.8/README.Gentoo
@@ -0,0 +1,30 @@
+-*- outline -*- $Id: README.Gentoo,v 1.1 2006/01/03 18:31:51 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.8/customize-target-features.lisp-prefix b/dev-lisp/sbcl/files/0.9.8/customize-target-features.lisp-prefix
new file mode 100644
index 000000000000..40f9a4fc85fa
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.9.8/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.8/customize-target-features.lisp-suffix b/dev-lisp/sbcl/files/0.9.8/customize-target-features.lisp-suffix
new file mode 100644
index 000000000000..dbbde7adc44e
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.9.8/customize-target-features.lisp-suffix
@@ -0,0 +1,2 @@
+)
+list)
diff --git a/dev-lisp/sbcl/files/0.9.8/install-clc.lisp b/dev-lisp/sbcl/files/0.9.8/install-clc.lisp
new file mode 100644
index 000000000000..c8e0a93a729f
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.9.8/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.8/sbcl-gentoo.patch b/dev-lisp/sbcl/files/0.9.8/sbcl-gentoo.patch
new file mode 100644
index 000000000000..06b6871c121a
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.9.8/sbcl-gentoo.patch
@@ -0,0 +1,70 @@
+diff -ur sbcl-0.9.8.orig/contrib/sb-bsd-sockets/sb-bsd-sockets.asd sbcl-0.9.8/contrib/sb-bsd-sockets/sb-bsd-sockets.asd
+--- sbcl-0.9.8.orig/contrib/sb-bsd-sockets/sb-bsd-sockets.asd 2004-08-02 06:42:56.000000000 -0500
++++ sbcl-0.9.8/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.8/contrib/sb-bsd-sockets: sb-bsd-sockets.asd.~1.22.~
+diff -ur sbcl-0.9.8.orig/contrib/sb-posix/sb-posix.asd sbcl-0.9.8/contrib/sb-posix/sb-posix.asd
+--- sbcl-0.9.8.orig/contrib/sb-posix/sb-posix.asd 2004-08-04 05:54:18.000000000 -0500
++++ sbcl-0.9.8/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.8/contrib/sb-posix: sb-posix.asd.~1.11.~
+diff -ur sbcl-0.9.8.orig/src/runtime/runtime.c sbcl-0.9.8/src/runtime/runtime.c
+--- sbcl-0.9.8.orig/src/runtime/runtime.c 2005-09-21 10:01:15.000000000 -0500
++++ sbcl-0.9.8/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.8/sbcl.sh b/dev-lisp/sbcl/files/0.9.8/sbcl.sh
new file mode 100644
index 000000000000..66253874d2a3
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.9.8/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.8/sbclrc b/dev-lisp/sbcl/files/0.9.8/sbclrc
new file mode 100644
index 000000000000..91f31720d896
--- /dev/null
+++ b/dev-lisp/sbcl/files/0.9.8/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.8 b/dev-lisp/sbcl/files/digest-sbcl-0.9.8
new file mode 100644
index 000000000000..63ea39f0b4da
--- /dev/null
+++ b/dev-lisp/sbcl/files/digest-sbcl-0.9.8
@@ -0,0 +1,6 @@
+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 8786757c40bcb1f889e4cdc8ce6bb29f sbcl-0.9.7-x86-64-linux-binary.tar.bz2 8003030
+MD5 4a8a3de71aff073b4e23e5bc2e432b27 sbcl-0.9.8-source.tar.bz2 2674853
diff --git a/dev-lisp/sbcl/sbcl-0.9.7.ebuild b/dev-lisp/sbcl/sbcl-0.9.7.ebuild
index 1b8f730ee802..e57f551e9963 100644
--- a/dev-lisp/sbcl/sbcl-0.9.7.ebuild
+++ b/dev-lisp/sbcl/sbcl-0.9.7.ebuild
@@ -1,6 +1,6 @@
-# Copyright 1999-2005 Gentoo Foundation
+# Copyright 1999-2006 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/sbcl-0.9.7.ebuild,v 1.3 2005/12/21 12:37:46 agriffis Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/sbcl-0.9.7.ebuild,v 1.4 2006/01/03 18:31:51 mkennedy Exp $
inherit common-lisp-common-2 eutils
@@ -133,7 +133,7 @@ src_install() {
if ! use nosource; then
# install the SBCL source
cp -pPR ${S}/src ${D}/usr/$(get_libdir)/sbcl
- find ${D}/$(get_libdir)/sbcl/src -type f -name \*.fasl -print0 | xargs -0 rm -f
+ find ${D}/usr/$(get_libdir)/sbcl/src -type f -name \*.fasl -print0 | xargs -0 rm -f
fi
impl-save-timestamp-hack sbcl || die
diff --git a/dev-lisp/sbcl/sbcl-0.9.8.ebuild b/dev-lisp/sbcl/sbcl-0.9.8.ebuild
new file mode 100644
index 000000000000..4c13bd313316
--- /dev/null
+++ b/dev-lisp/sbcl/sbcl-0.9.8.ebuild
@@ -0,0 +1,153 @@
+# Copyright 1999-2006 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/dev-lisp/sbcl/sbcl-0.9.8.ebuild,v 1.1 2006/01/03 18:31:51 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.9.7
+
+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
+ 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 )"
+# mirror://sourceforge/sbcl/${P}-html.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=${WORKDIR}/files
+
+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() {
+ local a
+
+ mkdir -p ${MY_WORK}
+ cp ${FILESDIR}/${PV}/* ${MY_WORK}
+ sed -i "s,/usr/lib,/usr/$(get_libdir),g" ${MY_WORK}/*
+
+ for a in ${A}; do [[ $a == *binary* ]] && break; done
+ unpack $a
+ mv ${PN}* sbcl-binary || die
+
+ unpack ${P}-source.tar.bz2
+ epatch ${MY_WORK}/sbcl-gentoo.patch || die
+ sed -i "s,/lib,/$(get_libdir),g" ${S}/install.sh
+ sed -i "s,\\(.*SBCL_HOME.*\\)/usr/lib,\\1/usr/$(get_libdir),g" ${S}/src/runtime/runtime.c
+
+ 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 -print0 | xargs -0 rm -f
+ find ${S} -depth -type d -name CVS -print0 | xargs -0 rm -rf
+ find ${S} -type f -name \*.c -print0 | xargs -0 chmod 644
+}
+
+src_compile() {
+ local bindir="${WORKDIR}/sbcl-binary"
+
+ 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 || die # Gentoo specific (from Debian)
+ dosed "s,/usr/lib/,/usr/$(get_libdir)/,g" /etc/sbclrc
+
+ exeinto /usr/$(get_libdir)/common-lisp/bin
+ doexe ${MY_WORK}/sbcl.sh || die # 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
+ cp -pPR ${S}/src ${D}/usr/$(get_libdir)/sbcl
+ find ${D}/usr/$(get_libdir)/sbcl/src -type f -name \*.fasl -print0 | xargs -0 rm -f
+ 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
+}