diff options
author | asau <asau@pkgsrc.org> | 2010-03-15 05:20:13 +0000 |
---|---|---|
committer | asau <asau@pkgsrc.org> | 2010-03-15 05:20:13 +0000 |
commit | 6e5a54eba0c4c478cea01b69c854228f7f3a51ff (patch) | |
tree | a8714bbd2fa44377f3833ce6208a85edaa3985ec | |
parent | 30a776c80c5d34c8faa5a9fbcc95f5c872596d48 (diff) | |
download | pkgsrc-6e5a54eba0c4c478cea01b69c854228f7f3a51ff.tar.gz |
Update to ECL 10.3.1, contributed by Matthew Mondor.
ECL 10.3.1:
===========
This release has three important focuses: performance improvements in various
fronts (garbage collection and hash tables), extending the run-process function
and important fixes to let ECL work better with Slime. To quote one lisper
ECL "this feels like a real Lisp implementation now"
* Bugs fixed:
- DIRECTORY used stat() also on files that did not match the directory masks.
- The syntax for matching strings in DIRECTORY is now the same as in
PATHNAME-MATCH-P. Formerly there were small differences, such as DIRECTORY
understanding characters #\? and #\\ and PATHNAME-MATCH-P not.
- Standalone executables do not require the existence of the ECLDIR directory
to start up -- it may be required, though, for working Unicode because the
encodings are stored there.
- PROCESS-JOIN was exported from the wrong package.
- PROCESS-JOIN failed when invoked with a thread that was in the process of
being set up.
- The output values of a process or thread are now collected in the process
object and returned by PROCESS-JOIN.
- ECL's interrupt servicing thread could not be shut down.
- When compiling LET forms, ECL emitted warnings about removal of variables
even when they were declared IGNORABLE.
- An internal variable MP:*ALLOW-WITH-INTERRUPTS* was not declared special.
- The compiler now understands function type proclamations with &OPTIONAL
values.
- The compiler now accepts THE special forms with a VALUES type.
- If file A.lsp explicitely loads B.lsp to use a package that is only defined
in B, then ECL signaled an error in the compiled version of A even after
this one had required B.lsp.
- ECL accepts FTYPE proclamations for SETF-functions.
- On platforms where a stack overflow does not trigger a SIGSEGV, ECL was
unable to recover from the overflow. Now it jumps to the outermost
protection frame (typically the toplevel).
- Socket streams are now two-way streams. This solves a problem with certain
platforms (OS X) where a C stream can not be used to read and write
simultaneously by two different threads.
- TRUENAME and PROBE-FILE were not thread safe.
* Visible changes:
- Hash tables now use hand-coded specialized loops for EQ, EQL, EQUAL, EQUALP
and package types, achieving a reduction of about 30% time in lookups.
- A new function EXT:ENVIRON returns the list of strings that makes up the
process environment. This is the equivalent of POSIX (char **environ)
and Windows' GetEnvironmentStrings.
- EXT:RUN-PROGRAM now accepts a keyword argument, :ENVIRON, with a list of
strings used to configure the environment of the child process. For instance
'("PWD=/home" "PATH=/usr/bin")
- EXT:RUN-PROGRAM returns as third value an EXT:EXTERNAL-PROCESS structure,
which supports the queries EXT:EXTERNAL-PROCESS-{PID,INPUT,OUTPUT,STATUS},
following CCL's conventions.
- The new function EXT:EXTERNAL-PROCESS-WAIT can be used to wait indefinitely
for termination of a process or simply to query its status.
- ECL implements a new garbage collector marking mode which at the overhead of
one word per object achieves precise marking of heap objects, reducing
accidental data retention and improving the time spent in garbage
collection. This mode is only available when using --enable-boehm=system at
configuration time.
- ECL now ships with ASDF version 1.604
- The variables C:*USER-CC-FLAGS* and C:*USER-LD-FLAGS* are lists of strings
which can used to change the behavior of the C compiler and the
linker. Note, however, that the flags that ECL uses may take priority.
- In the C code we are beginning to use GCC's attributes (__attribute__) and
branch annotation (__builtin_expect). This decreases the size of code that
checks for errors and improves performance.
- When printing compiler notes, instead of printing the macroexpanded form,
ECL now prints the toplevel form, as follows
;;; Warning: in file src:lsp;autoload.lsp.NEWEST, position 1178 and top form
;;; (DEFMACRO WITH-COMPILATION-UNIT (OPTIONS &REST BODY) ...)
;;; The variable OPTIONS is not used.
- ECL now implements EXT:*INVOKE-DEBUGGER-HOOK*, which works like *DEBUGGER-HOOK*
but is also observed by BREAK. (SBCL extension adopted by ECL)
- The UFFI interface now supports C99 types, such as :int8-t, :uint32-t, etc,
but only when the corresponding types do exist in the underlying C environment.
- SOCKET-MAKE-STREAM defaults :BUFFERING to :FULL and allows three new keyword
arguments, :INPUT, :OUTPUT and :EXTERNAL-FORMAT, as in SBCL.
- COMPILE-FILE admits the keyword argument :EXTERNAL-FORMAT.
- A new function EXT:ALL-ENCODINGS lists all encondings known to ECL.
- Improved readability of compiler messages.
- SERVE-EVENT now allows time resolution of less than one second.
- The PROFILE package now has an alias, SB-PROFILE.
- ECL now stores the location of its source files in a logical hostname,
"SRC:", which points to the directory where Announcement is located.
- When building ECL, if "etags" is installed, a file TAGS is created which
contains references to the location of all C functions. This file can be
used to locate functions from the core library in Slime, using M-.
- Documentation files now allow for annotation of arbitrary symbols,
based on a key and a sub-key which are both symbols.
- New function EXT:FUNCTION-LAMBDA-LIST which currently only works with
functions from the core ECL library, generic functions and interpreted
functions.
- The debugger now is capable of showing the special variable bindings
from a function, as well as the restarts newly bound by that function.
- When using git, a new function EXT:LISP-IMPLEMENTATION-VCS-ID returns a
unique identifier denoting the last commit. This can be used to discriminate
between unstable releases and remove stale FASL files.
- COMPILE-FILE admits two new keyword arguments, :SOURCE-TRUENAME and
:SOURCE-OFFSET which can be used to change the value returned by
EXT:COMPILED-FUNCTION-FILE when acting on compiled functions.
-rw-r--r-- | lang/ecl/DESCR | 3 | ||||
-rw-r--r-- | lang/ecl/Makefile | 10 | ||||
-rw-r--r-- | lang/ecl/PLIST | 5 | ||||
-rw-r--r-- | lang/ecl/buildlink3.mk | 4 | ||||
-rw-r--r-- | lang/ecl/distinfo | 8 | ||||
-rw-r--r-- | lang/ecl/options.mk | 25 |
6 files changed, 44 insertions, 11 deletions
diff --git a/lang/ecl/DESCR b/lang/ecl/DESCR index 1e1374a2d17..cf234682344 100644 --- a/lang/ecl/DESCR +++ b/lang/ecl/DESCR @@ -15,3 +15,6 @@ The current ECL implementation features: * The Gnu Multiprecision library for fast bignum operations. * A simple conservative mark & sweep garbage collector. * The Boehm-Weiser garbage collector. + * Threads using the POSIX threads library. + * CLX, an X11 client not needing extra X11 libraries. + * Unicode. diff --git a/lang/ecl/Makefile b/lang/ecl/Makefile index bfec1f342e9..03c31501e11 100644 --- a/lang/ecl/Makefile +++ b/lang/ecl/Makefile @@ -1,7 +1,7 @@ -# $NetBSD: Makefile,v 1.7 2009/12/15 15:14:54 asau Exp $ +# $NetBSD: Makefile,v 1.8 2010/03/15 05:20:13 asau Exp $ # -DISTNAME= ecl-9.12.3 +DISTNAME= ecl-10.3.1 CATEGORIES= lang MASTER_SITES= ${MASTER_SITE_SOURCEFORGE:=ecls/} EXTRACT_SUFX= .tgz @@ -22,6 +22,12 @@ INFO_FILES= yes CONFIGURE_ARGS+= --enable-boehm=system --with-system-gmp +SUBST_CLASSES+= fix-libffi-include +SUBST_STAGE.fix-libdir= post-patch +SUBST_MESSAGE.fix-libdir= Fixing libffi layout. +SUBST_FILES.fix-libdir= src/c/ffi.d +SUBST_SED.fix-libdir= -e '/include.*<ffi/ffi.h>/s:ffi/ffi.h:ffi.h:' + .include "options.mk" PLIST_SUBST= PKGVERSION_MAJOR_MINOR=${PKGVERSION_NOREV:R} \ diff --git a/lang/ecl/PLIST b/lang/ecl/PLIST index f2ba341ed11..aaa3fe548ec 100644 --- a/lang/ecl/PLIST +++ b/lang/ecl/PLIST @@ -1,4 +1,4 @@ -@comment $NetBSD: PLIST,v 1.6 2009/10/11 11:15:40 asau Exp $ +@comment $NetBSD: PLIST,v 1.7 2010/03/15 05:20:13 asau Exp $ bin/ecl bin/ecl-config include/ecl/bytecodes.h @@ -17,9 +17,12 @@ include/ecl/page.h include/ecl/stacks.h include/ecl/unify.h lib/${PKGNAME}/BUILD-STAMP +lib/${PKGNAME}/TAGS lib/${PKGNAME}/asdf.fas lib/${PKGNAME}/bytecmp.asd lib/${PKGNAME}/bytecmp.fas +${PLIST.clx}lib/${PKGNAME}/clx.asd +${PLIST.clx}lib/${PKGNAME}/clx.fas lib/${PKGNAME}/cmp.asd lib/${PKGNAME}/cmp.fas lib/${PKGNAME}/defsystem.asd diff --git a/lang/ecl/buildlink3.mk b/lang/ecl/buildlink3.mk index d034ac8cad2..91e3e6c1f7b 100644 --- a/lang/ecl/buildlink3.mk +++ b/lang/ecl/buildlink3.mk @@ -1,11 +1,11 @@ -# $NetBSD: buildlink3.mk,v 1.3 2009/03/20 19:24:48 joerg Exp $ +# $NetBSD: buildlink3.mk,v 1.4 2010/03/15 05:20:13 asau Exp $ BUILDLINK_TREE+= ecl .if !defined(ECL_BUILDLINK3_MK) ECL_BUILDLINK3_MK:= -BUILDLINK_API_DEPENDS.ecl+= ecl>=0.9.12 +BUILDLINK_API_DEPENDS.ecl+= ecl>=10.3.1 BUILDLINK_PKGSRCDIR.ecl?= ../../lang/ecl .include "../../devel/boehm-gc/buildlink3.mk" diff --git a/lang/ecl/distinfo b/lang/ecl/distinfo index ea9f5dbb8ae..2329e4d8f89 100644 --- a/lang/ecl/distinfo +++ b/lang/ecl/distinfo @@ -1,5 +1,5 @@ -$NetBSD: distinfo,v 1.6 2009/12/15 15:14:54 asau Exp $ +$NetBSD: distinfo,v 1.7 2010/03/15 05:20:13 asau Exp $ -SHA1 (ecl-9.12.3.tgz) = cf293b029f33b0b0f9539e9163618a9d31df6f30 -RMD160 (ecl-9.12.3.tgz) = 10deb139394edffce8f1f7f4b1c682b9a86f93d9 -Size (ecl-9.12.3.tgz) = 5758828 bytes +SHA1 (ecl-10.3.1.tgz) = b3e95fc0bf10ab953fffc04badbc28df1e1e37fc +RMD160 (ecl-10.3.1.tgz) = e8c6dce125c973bc4e3ad07035046aad7bb6ca8c +Size (ecl-10.3.1.tgz) = 5906221 bytes diff --git a/lang/ecl/options.mk b/lang/ecl/options.mk index 971bce226b7..792d571586f 100644 --- a/lang/ecl/options.mk +++ b/lang/ecl/options.mk @@ -1,7 +1,7 @@ -# $NetBSD: options.mk,v 1.2 2009/08/19 14:21:03 asau Exp $ +# $NetBSD: options.mk,v 1.3 2010/03/15 05:20:13 asau Exp $ PKG_OPTIONS_VAR= PKG_OPTIONS.ecl -PKG_SUPPORTED_OPTIONS+= threads unicode +PKG_SUPPORTED_OPTIONS+= threads unicode ffi clx PKG_SUGGESTED_OPTIONS+= # empty # Unicode support proved to break Axioms. # Threads are off, since threaded ECL requires threads support @@ -16,6 +16,11 @@ CONFIGURE_ARGS+= --enable-threads --enable-debug CONFIGURE_ENV+= THREAD_CFLAGS=${PTHREAD_CFLAGS:Q} CONFIGURE_ENV+= THREAD_LDLAGS=${BUILDLINK_LDLAGS.pthread:Q} CONFIGURE_ENV+= THREAD_LIBS=${BUILDLINK_LIBS.pthread:Q} +.if ${OPSYS} == "FreeBSD" || ${OPSYS} == "Linux" || ${OPSYS} == "Darwin" +CONFIGURE_ARGS+= --with-__thread=yes +.else +CONFIGURE_ARGS+= --with-__thread=no +.endif .include "../../mk/pthread.buildlink3.mk" .endif @@ -23,3 +28,19 @@ CONFIGURE_ENV+= THREAD_LIBS=${BUILDLINK_LIBS.pthread:Q} CONFIGURE_ARGS+= --enable-unicode PLIST_SRC+= PLIST.unicode .endif + +.if !empty(PKG_OPTIONS:Mffi) +.include "../../devel/libffi/buildlink3.mk" +.endif + +.if !empty(PKG_OPTIONS:Mclx) +CONFIGURE_ARGS+= --with-clx +.endif + +PLIST_VARS+= clx + +.for option in clx +. if !empty(PKG_OPTIONS:M${option}) +PLIST.${option}= yes +. endif +.endfor |