pkgsrc-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[pkgsrc/trunk]: pkgsrc/lang/ecl ecl: Update to 16.1.3

branches:  trunk
changeset: 320149:e97e3c196923
user:      leot <>
date:      Fri Mar 01 13:30:52 2019 +0000

ecl: Update to 16.1.3

pkgsrc changes:
 - Remove clx option. Bundled clx is no longer provided by ecl

** Announcement
Dear Community,

After almost a year of development we are proud to present a new release of
ECL tagged with version =16.1.3=. All changes are backward compatible
fixing bugs and other issues, implementing new interfaces and cleaning up
the code base.

ECL manual has been updated in a few places. Work on a new documentation is
still pending. It is still incomplete, but you may check see it here:

Before this release we have performed extensive tests on various platforms
(Linux, FreeBSD, OpenBSD, NetBSD, OSX, Windows MSVC, Windows MinGW, Windows
Cygwin, Android and Haiku). For details please consult Extra attention
has been paid to Windows testing to improve that platform support.

Best regards,
ECL Development Team

** API changes
- Added better interface for package-locks.

  Introduced functions:
  =ext:package-locked-p package=
  =ext:lock-package package=
  =ext:unlock-package package=

  To use these functions user has to require the module
  #+BEGIN_SRC lisp
    (require '#:package-locks)

  =defpackage= accepts new option =lock= to allow locking package on

  #+BEGIN_SRC lisp
    (defpackage foo (:lock t))

- =mp:holding-lock-p=: introduce new function for multiprocessing. Function
  verifies if lock is hold by the thread which calls the function. Usage:
  =(mp:holding-lock-p my-lock)=.

- =make-random-state=: fix problem with simple-vectors. The correct
  initialization types for =make-random-state= are: =(OR RANDOM-STATE

  Initializing a random state with an appropriate array (element type and
  arity dependent on platform) is also possible.

- =ext:random-state-array=: new extension for random-states. Usage:
  =(ext:random-state-array random-state)=.

- =ext:terminate-process=: new extension for external processes. Usage:
  =(ext:terminate-process process)= with a second, optional boolean
  argument whenever termination should be forced or not.

** Enhancements
- Implemented =CDR-7=.

- implemented CDRs: =CDR-1=, =CDR-5=, =CDR-14=. Both =CDR-1= and =CDR-5=
  were already implemented, CDR-14 made us to list them in =*features*=

- if ECL is build with =--with-cxx= option, =:CXX-CORE= is present in

- deprecated configure option =--with-local-gmp= has been removed - use
  =--enable-gmp= (defaults to auto).

- configure options has been revised.

- ASDF has been upgraded to version (with a few patches scheduled
  for 3.2.0).

- bundled CLX has been purged. Lately I've fixed ECL support on portable
  CLX maintained by sharplispers on
  (available via QuickLisp).

- initial port for the Haiku platform. The port is done by Kacper Kasper's
  work, one of Haiku developers. Threads are not supported yet.

- refactored ECL internal tests framework. Tests in =src/tests= are now
  asdf-loadable (with =load-source-op=) and divided into test suites. =make
  check= target runs all regression and feature tests which aren't supposed
  to fail.

- removed 15000 lines of obsolete code. Files not included in the
  buildsystem but lingering in the codebase or options failing to
  build. All info is added in the new documentation in the section "Removed

- improved man page and help output. Man page now contains up-to-date list
  of flags, as well as explanation of flag's behavior.

- deprecated long flags with one dash, added two-dash version. Flags that
  aren't one-character, but start with one dash (e.g. =-eval=) are now
  deprecated; long version =--eval= was added instead.

- indented C/C++ code to follow emacs's gnu C style.  This is a first step
  towards coding standards in the documentation. Additionally all in the
  src/c/ directory are listed in the appropraite documentation section

- refactored =list_current_directory in unixfsys.d=. Function was
  obfuscated with ifdefs with non-even pairs of =#\{= and =#\}=.

** Issues fixed
- ECL signals floating point exceptions in top-level console.

- =mp:rwlock= is treated as built-in class (previously process crashed if
  =class-of= was called on such object).

- ECL builds now succesfully with =--with-ieee-fp=no= option.

- =ext:file-stream-fd=: doesn't cause an internal-error if called with
  something not being a =file-stream= (signals a =SIMPLE-TYPE-ERROR=

- =stable-sort=: bugfix and improvement in speed. Adapted from SBCL by
  Diogo Franco.

- typep: accept =*= type specifier as abbreviation of =T= as described in
  =2.4.3 Type Specifiers= of the specification.

- MOP: fix problemes when redefining non-standard and anonymous
  classes. Bugs identified and fixed by Pascal Costanza.

- =getcwd=: fix issue with too long pathname. This fixes the regression,
  which crashed ECL at start when pathname exceeded 128 characters limit.

- =make-random-state=: fix a problem with simple-vectors. Until now =#$=
  reader macro accepted simple vectors as an argument, what lead to bugs if
  vector didn't match specific requirements like the element type or the
  arity. Now we sanitize this.

- =make-load-form=: provide implementation for random-state objects.

- thread fix on msvc: on windows importing thread was closing the thread
  handler so the thread wakeup wasn't working because the handler is not
  more valid.

- import thread wasn't set upping a proper environment: on some case the
  thread was mistakenly thinking that the thread was already registered.

- =ECL_HANDLER_CASE= and =ECL_RESTART_CASE= didn't work as expected. Bug
  identified and fixed by Vadim Penzin.


 lang/ecl/DESCR      |   1 -
 lang/ecl/Makefile   |   8 ++++----
 lang/ecl/PLIST      |  15 +++++++++------
 lang/ecl/distinfo   |  10 +++++-----
 lang/ecl/ |  25 +++++++------------------
 5 files changed, 25 insertions(+), 34 deletions(-)

diffs (153 lines):

diff -r 649c19a204c6 -r e97e3c196923 lang/ecl/DESCR
--- a/lang/ecl/DESCR    Fri Mar 01 13:05:37 2019 +0000
+++ b/lang/ecl/DESCR    Fri Mar 01 13:30:52 2019 +0000
@@ -16,5 +16,4 @@
   * 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 -r 649c19a204c6 -r e97e3c196923 lang/ecl/Makefile
--- a/lang/ecl/Makefile Fri Mar 01 13:05:37 2019 +0000
+++ b/lang/ecl/Makefile Fri Mar 01 13:30:52 2019 +0000
@@ -1,8 +1,8 @@
-# $NetBSD: Makefile,v 1.24 2018/07/04 13:40:21 jperkin Exp $
+# $NetBSD: Makefile,v 1.25 2019/03/01 13:30:52 leot Exp $
-DISTNAME=              ecl-16.1.2
+DISTNAME=              ecl-16.1.3
 CATEGORIES=            lang
 EXTRACT_SUFX=          .tgz
@@ -16,7 +16,7 @@
 USE_TOOLS+=            gmake makeinfo
 INFO_FILES=            yes
-CONFIGURE_ARGS+=       --enable-boehm=system --with-system-gmp
+CONFIGURE_ARGS+=       --enable-boehm=system --enable-gmp=system
 SUBST_CLASSES+=                        fix-libffi-include
 SUBST_STAGE.fix-libdir=                pre-configure
diff -r 649c19a204c6 -r e97e3c196923 lang/ecl/PLIST
--- a/lang/ecl/PLIST    Fri Mar 01 13:05:37 2019 +0000
+++ b/lang/ecl/PLIST    Fri Mar 01 13:30:52 2019 +0000
@@ -1,9 +1,11 @@
-@comment $NetBSD: PLIST,v 1.12 2016/03/11 20:32:30 asau Exp $
+@comment $NetBSD: PLIST,v 1.13 2019/03/01 13:30:52 leot Exp $
@@ -21,13 +23,11 @@
@@ -200,7 +200,6 @@
@@ -208,12 +207,15 @@
@@ -233,3 +235,4 @@
+@pkgdir include/ecl/gc/private
diff -r 649c19a204c6 -r e97e3c196923 lang/ecl/distinfo
--- a/lang/ecl/distinfo Fri Mar 01 13:05:37 2019 +0000
+++ b/lang/ecl/distinfo Fri Mar 01 13:30:52 2019 +0000
@@ -1,6 +1,6 @@
-$NetBSD: distinfo,v 1.19 2016/03/11 20:32:30 asau Exp $
+$NetBSD: distinfo,v 1.20 2019/03/01 13:30:52 leot Exp $
-SHA1 (ecl-16.1.2.tgz) = 73a972fa5e42d019a83d9f13447c6e6e080b9af3
-RMD160 (ecl-16.1.2.tgz) = f1b3ab9309cea2fe350fb39b141ea29c670e851e
-SHA512 (ecl-16.1.2.tgz) = f204494907226a12b4ecabc39d555f27c1ce5cba515fccd187d9b7ee584d86278558d6a26b2bbec98bce582239f21ac00c2d854f594c6b1f21e1636793845926
-Size (ecl-16.1.2.tgz) = 7449461 bytes
+SHA1 (ecl-16.1.3.tgz) = a0db6c435dcc33404b0a2a4a402e1f2edc169e95
+RMD160 (ecl-16.1.3.tgz) = 320e93e4abe62fa1fe9e36688ba040eef8ae8923
+SHA512 (ecl-16.1.3.tgz) = 5d743f422f6bc24671abf4c739cde8273d08f056906a1ef8aed5145c703b6d52c7fa4b5e0be8c125f32240c20ce053007786bb3ae81cc34d47791f6fae0819c1
+Size (ecl-16.1.3.tgz) = 7459212 bytes
diff -r 649c19a204c6 -r e97e3c196923 lang/ecl/
--- a/lang/ecl/       Fri Mar 01 13:05:37 2019 +0000
+++ b/lang/ecl/       Fri Mar 01 13:30:52 2019 +0000
@@ -1,8 +1,8 @@
-# $NetBSD:,v 1.10 2016/07/05 01:26:59 dholland Exp $
+# $NetBSD:,v 1.11 2019/03/01 13:30:52 leot Exp $
 PKG_OPTIONS_VAR=               PKG_OPTIONS.ecl
-PKG_SUPPORTED_OPTIONS+=                debug threads unicode ffi clx
-PKG_SUGGESTED_OPTIONS+=                unicode ffi clx
+PKG_SUPPORTED_OPTIONS+=                debug threads unicode ffi
+PKG_SUGGESTED_OPTIONS+=                unicode ffi
 # Unicode support proved to break Axioms.
 # Threads are off, since threaded ECL requires threads support
 # in Boehm GC (off by default).
@@ -44,24 +44,13 @@
 CONFIGURE_ARGS+=       --with-dffi=no
-.if !empty(PKG_OPTIONS:Mclx)
-CONFIGURE_ARGS+=       --with-clx
+PLIST_VARS+=           unicode
+.if !empty(PKG_OPTIONS:Municode)
+PLIST.unicode= yes
-PLIST_VARS+=           clx unicode
-.for option in clx unicode
-.  if !empty(PKG_OPTIONS:M${option})
-PLIST.${option}=       yes
-.  endif
 # Help generating PLIST:
-.if !empty(PKG_OPTIONS:Mclx)
-PRINT_PLIST_AWK+=      {if ($$0 ~ /lib\/.*\/libclx.a$$/) {$$0 = "$${PLIST.clx}" $$0;}}
-PRINT_PLIST_AWK+=      {if ($$0 ~ /lib\/.*\/clx.(asd|fas)$$/) {$$0 = "$${PLIST.clx}" $$0;}}
 .if !empty(PKG_OPTIONS:Municode)
 PRINT_PLIST_AWK+=      {if ($$0 ~ /lib\/.*\/encodings\//) {$$0 = "$${PLIST.unicode}" $$0;}}

Home | Main Index | Thread Index | Old Index