summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--dev-lisp/ecls/ChangeLog6
-rw-r--r--dev-lisp/ecls/Manifest6
-rw-r--r--dev-lisp/ecls/ecls-0.9f_p1.ebuild7
-rw-r--r--dev-lisp/ecls/files/README.Gentoo30
-rw-r--r--dev-lisp/ecls/files/clc-lite.lisp112
5 files changed, 157 insertions, 4 deletions
diff --git a/dev-lisp/ecls/ChangeLog b/dev-lisp/ecls/ChangeLog
index 02e0c4f06ef8..33e8b9a6eded 100644
--- a/dev-lisp/ecls/ChangeLog
+++ b/dev-lisp/ecls/ChangeLog
@@ -1,6 +1,10 @@
# ChangeLog for dev-lisp/ecls
# Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/dev-lisp/ecls/ChangeLog,v 1.17 2005/05/30 08:18:54 mkennedy Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-lisp/ecls/ChangeLog,v 1.18 2005/06/07 01:44:37 mkennedy Exp $
+
+ 07 Jun 2005; Matthew Kennedy <mkennedy@gentoo.org> +files/README.Gentoo,
+ +files/clc-lite.lisp, ecls-0.9f_p1.ebuild:
+ Minimal Common Lisp Controller support via. clc-lite.lisp
30 May 2005; <mkennedy@gentoo.org> ecls-0.9f_p1.ebuild:
Keywording ~sparc
diff --git a/dev-lisp/ecls/Manifest b/dev-lisp/ecls/Manifest
index fa6058a6d949..a8be755fffea 100644
--- a/dev-lisp/ecls/Manifest
+++ b/dev-lisp/ecls/Manifest
@@ -2,12 +2,14 @@ MD5 4f64988d98f66a29cffcf99a0b4aa03a ChangeLog 2906
MD5 3919e39c68e2886e4646f6dd01dbe091 ecls-0.9d.ebuild 1163
MD5 56dfa35ee6f95b523278bd352e2ff856 ecls-0.9e.ebuild 1198
MD5 c4fffb85c7522845dc9697f7a8f4cb49 metadata.xml 459
-MD5 fd6197f5270c4aed541a1a14961a80a9 ecls-0.9f_p1.ebuild 1438
+MD5 71752ed4422123c66e9b3bc32296da11 ecls-0.9f_p1.ebuild 1549
+MD5 724bb27333efdd7d76a33649fb9cba42 files/clc-lite.lisp 3708
MD5 198230b69b41ed542ae8fa6b0c244b3d files/0.9d-headers-gentoo.patch 1031
MD5 da3449e23eb91bb9c935b607ddb29cfd files/0.9d-texinfo-gentoo.patch 1653
MD5 7704324472963a25c8e77a29f0726936 files/0.9e-headers-gentoo.patch 1007
MD5 85eaeaa0b49394eb387611e16263048b files/0.9e-texinfo-gentoo.patch 1659
MD5 7bc96db7aefcaaa816c3270fa705f453 files/digest-ecls-0.9d 58
MD5 238a130d754b44f0cbe42ad2434ae921 files/digest-ecls-0.9e 64
-MD5 2ba8aaefc66baa0e17b930bf9324a3ee files/0.9f_p1-headers-gentoo.patch 1007
+MD5 1163df4f9cd552f3ca13962c03fa4f65 files/README.Gentoo 1541
MD5 5bc7b2d9d3b3af9e6f6add98470aa1a3 files/digest-ecls-0.9f_p1 66
+MD5 2ba8aaefc66baa0e17b930bf9324a3ee files/0.9f_p1-headers-gentoo.patch 1007
diff --git a/dev-lisp/ecls/ecls-0.9f_p1.ebuild b/dev-lisp/ecls/ecls-0.9f_p1.ebuild
index d300ee69ee44..0d36c3346817 100644
--- a/dev-lisp/ecls/ecls-0.9f_p1.ebuild
+++ b/dev-lisp/ecls/ecls-0.9f_p1.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2005 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/dev-lisp/ecls/ecls-0.9f_p1.ebuild,v 1.2 2005/05/30 08:18:54 mkennedy Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-lisp/ecls/ecls-0.9f_p1.ebuild,v 1.3 2005/06/07 01:44:37 mkennedy Exp $
inherit eutils
@@ -24,6 +24,8 @@ DEPEND="X? ( virtual/x11 )
IUSE="X"
+PROVIDE="virtual/commonlisp"
+
S=${WORKDIR}/ecl-${PV:0:4}
src_unpack() {
@@ -54,4 +56,7 @@ src_install () {
docdir=${D}/usr/share/doc/${PF} install || true
dohtml doc/*.html
dodoc ANNOUNCEMENT Copyright LGPL
+
+ insinto /usr/share/doc/${PF}/
+ doins ${FILESDIR}/{clc-lite.lisp,README.Gentoo}
}
diff --git a/dev-lisp/ecls/files/README.Gentoo b/dev-lisp/ecls/files/README.Gentoo
new file mode 100644
index 000000000000..40221f9f95ba
--- /dev/null
+++ b/dev-lisp/ecls/files/README.Gentoo
@@ -0,0 +1,30 @@
+-*- outline -*- $Id: README.Gentoo,v 1.1 2005/06/07 01:44:37 mkennedy Exp $
+
+Gentoo GNU/Linux specific notes for ECL
+---------------------------------------
+
+This is the README.Gentoo file from /usr/share/doc/@PF@/ directory.
+
+ * The Gentoo port includes a patch to ECL's installed header file (ech.h) so
+ that TRUE and FALSE are not redefined if they're already included from
+ elsewhere. This makes it easier to use ECL with other software which defines
+ those C preprocesser symbols (eg. glib-2.0).
+
+ * Support for a kind of Common Lisp Controller is available since
+ dev-lisp/ecls-0.9f_p1 but not enabled by default. The controller included in
+ ECL simply puts /usr/share/common-lisp/systems/ into ASDF:*CENTRAL-REGISTRY*
+ and extends ASDF:OUTPUT-FILES so that FASLs are placed into
+ /var/cache/common-lisp-controller/<username>/ecl/.
+
+ To use this controller, either copy /usr/share/doc/@PF@/clc-lite.lisp to
+ your ~/.eclrc or source it from there.
+
+ * ECL versus dev-lisp/cl-*: ECL 0.9f_p1 and later will compile a lot of the
+ dev-lisp/cl-* ports. Quite a few ports will fail however. Should you come
+ across a failure, consider isolating it in an ECL without the clc-lite.lisp
+ code loaded. Submit your results preferably to the Gentoo Bugzilla or to
+ upstream if you're absolutely sure it isn't Gentoo related.
+
+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/ecls/files/clc-lite.lisp b/dev-lisp/ecls/files/clc-lite.lisp
new file mode 100644
index 000000000000..80d0a2f161d6
--- /dev/null
+++ b/dev-lisp/ecls/files/clc-lite.lisp
@@ -0,0 +1,112 @@
+;;;; -*- mode: common-lisp; indent-tabs-mode: nil; package: common-lisp-controller -*-
+
+(defpackage #:common-lisp-controller
+ (:use #:common-lisp))
+
+(in-package #:common-lisp-controller)
+
+(defvar *source-root* #p"/usr/share/common-lisp/source/")
+
+(defvar *fasl-root* nil)
+
+(defvar *implementation-name* "ecl")
+
+(eval-when (:load-toplevel :compile-toplevel :execute)
+ (unless (member :asdf *features*)
+ (require 'asdf)))
+
+
+;; I cut this out of CMUCL
+
+(defun %enough-namestring (pathname &optional (defaults *default-pathname-defaults*))
+ (let* ((path-dir (pathname-directory pathname))
+ (def-dir (pathname-directory defaults))
+ (enough-dir
+ ;; Go down the directory lists to see what matches. What's
+ ;; left is what we want, more or less.
+ (cond ((and (eq (first path-dir) (first def-dir))
+ (eq (first path-dir) :absolute))
+ ;; Both paths are :absolute, so find where the common
+ ;; parts end and return what's left
+ (do* ((p (rest path-dir) (rest p))
+ (d (rest def-dir) (rest d)))
+ ((or (endp p) (endp d)
+ (not (equal (first p) (first d))))
+ `(:relative ,@p))))
+ (t
+ ;; At least one path is :relative, so just return the
+ ;; original path. If the original path is :relative,
+ ;; then that's the right one. If PATH-DIR is
+ ;; :absolute, we want to return that except when
+ ;; DEF-DIR is :absolute, as handled above. so return
+ ;; the original directory.
+ path-dir))))
+ (make-pathname :host (pathname-host pathname)
+ :directory enough-dir
+ :name (pathname-name pathname)
+ :type (pathname-type pathname)
+ :version (pathname-version pathname))))
+
+;; I cut this out of the original Common Lisp Controller v4 from Debian
+
+(defun calculate-fasl-root ()
+ "Inits common-lisp controller for this user"
+ (unless *fasl-root*
+ (setf *fasl-root*
+ ;; set it to the username of the user:
+ (let* (#-cmu
+ (homedir (pathname-directory
+ (user-homedir-pathname)))
+ ;; cmucl has searchlist home (!)
+ #+cmu
+ (homedirs (extensions:search-list "home:"))
+ #+cmu
+ (homedir (when homedirs
+ (pathname-directory
+ (first homedirs)))))
+ ;; strip off :re or :abs
+ (when (or (eq (first homedir)
+ :relative)
+ (eq (first homedir)
+ :absolute))
+ (setf homedir (rest homedir)))
+ ;; if it starts with home, nuke it
+ (when (string= (first homedir)
+ "home")
+ (setf homedir (rest homedir)))
+ ;; now append *implementation-name*
+ (setf homedir (append homedir
+ (list *implementation-name*)))
+ ;; this should be able to cope with
+ ;; homedirs like /home/p/pv/pvaneynd ...
+ (merge-pathnames
+ (make-pathname
+ :directory `(:relative ,@homedir))
+ #p"/var/cache/common-lisp-controller/")))))
+
+(defun source-root-path-to-fasl-path (source)
+ "Converts a path in the source root into the equivalent path in the fasl root"
+ (calculate-fasl-root)
+ (merge-pathnames
+ (%enough-namestring source (asdf::resolve-symlinks *source-root*))
+ *fasl-root*))
+
+(defmethod asdf:output-files :around ((op asdf:operation) (c asdf:component))
+ (let ((orig (call-next-method)))
+ (mapcar #'source-root-path-to-fasl-path orig)))
+
+(pushnew #p"/usr/share/common-lisp/systems/" asdf:*central-registry*)
+
+;;;; Some notes on ENOUGH-NAMESTRING on ECL
+
+;; NOTE enough-namestring might be broken on ECL
+;;
+;; > (enough-namestring #P"/usr/share/common-lisp/source/cl-ppcre/"
+;; #P"/usr/share/common-lisp/source/")
+;; "/usr/share/common-lisp/source/cl-ppcre/"
+
+: ; SBCL:
+;;
+;; CL-USER> (enough-namestring #P"/usr/share/common-lisp/source/cl-ppcre/"
+;; #P"/usr/share/common-lisp/source/")
+;; "cl-ppcre/"