pkgsrc-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[pkgsrc/trunk]: pkgsrc/lang/polyml Update to Poly/ML 5.5.1
details: https://anonhg.NetBSD.org/pkgsrc/rev/76c7c23aa853
branches: trunk
changeset: 627799:76c7c23aa853
user: asau <asau%pkgsrc.org@localhost>
date: Sun Dec 15 18:35:22 2013 +0000
description:
Update to Poly/ML 5.5.1
Contributed by Imre Vadasz on pkgsrc-users (slightly adapted).
Changes in Poly/ML Version 5.5.1
Major New Features and Changes
* The intermediate code optimiser has been largely rewritten.
The optimiser now detects various additional cases where a
closures or tuples can be stored on the stack rather than
requiring heap storage
* The match compiler that processes a sequence of patterns in a
case or fun-binding has been reworked. This now handles
complex matches that used to result in a code blow-up
* A"polyc" script has been added to aid compiling and linking
ML code to produce a stand-alone binary. This is intended as
an analogue of cc and gcc. The easiest way to build a binary
is now to put the ML code into a file (foo.ML) with a
function "main" that is the entry point to the code. Then run
polyc -o foo foo.ML
The script takes care of any libraries that may be required.
It does require that the poly binary and libraries have been
installed to the location that was specified in the configure
script.
* Set the default in the configure script not to build a shared
library. This can be overidden with --enable-shared. The
advantage of this is that binaries created from Poly/ML,
including poly itself, do not require libpolyml at run-time.
* Additions and changes to the command-line options when
starting the ML top-level
+ The --eval option can be followed by a string which is
compiled and executed before the top-level is entered
+ The --script option can be used to allow ML code to be
run as a script (a "shell script") in Unix. It reads the
file name given as the last option, skipping the first
line if it begins #!. Implies -q option. Note: because of
the way scripts pass their options if used this must be
the only option. To use ML as a script put the ML code
into a file, put
#! /usr/local/bin/poly --script
as the first line, modifying the path depending on where
poly is installed, and set the file to have execute
permission.
+ The -q option now sets the print depth to zero as well as
suppressing the start-up message
+ The input prompt (> or #) is only produced if the input
is a terminal. The -i option should be used to cause the
prompt to be produced if, for example, the input is from
a pipe.
Minor Additions and Changes
* The -H option now sets the initial heap size rather than
being a synonym for --minheap
* Add large file support
* When printing the fields a record print them in alphabetical
order rather than the system order used in the compiler
* Convert the representation of the statistics to use ASN1
encoding. This is byte-order and word-length independent and
allows 32-bit Poly/ML to read the statistics of 64-bit Poly/
ML on the same machine and vice-versa.
* Add a substructure Exception to the PolyML structure to hold
all the functions related to exceptions.
* The default for --gc-threads is now the number of independent
physical processors. Hyperthreaded cores are counted as
single cores rather than dual cores.
* Improve the GC and allocation code for very large arrays
* Improve handling of OS.Process.system in Cygwin
* Improved versions of Word32 and Word64. These are used for
SystemWord and LargeWord.
Bug Fixes
* Fix Word32.fromLargeInt which could return values outside the
range of Word32
* Fix segfault in PolyML.stackTrace
* Fix errors in conversion of string to real values
* Fix segfault when a thread created in foreign code called an
ML callback
* Fix profiler which could often report UNKNOWN function
* Fix bug with overlapped areas in ArraySlice.copy
* Fix InternalError exception with ML code where a fixed record
type could not be found
* Fix bug with equality on BoolVector.vector
* Raise the correct exception (Size) for negative lengths in
canInput and inputN
* Fix Real.fromInt with an argument that was an arbitrary
precision number in the long form
* Fix error in the timing information printed with
PolyML.timing true in Windows.
* Fix occasional problem with input/output as a result of the
stream token being represented by an immutable value but then
being checked for equality
* Fix bug in X86-64 code-generator with literal constants that
do not fit in 32-bits. It could result in an "InternalError:
gen32s: invalid word" exception. Includes regression test.
* Fix LargWord.fromInt which was wrong for large negative
values
* Fix bug in power-of-two function in code-generator. This
caused an infinite loop with Word.* when multiplying by a
constant with the highest bit set and not a power of two.
* Fix bug in structure matching code
* Use ELF_Rela relocation structures for all relocations in
X86-64. Some systems e.g. Solaris require this.
diffstat:
lang/polyml/Makefile | 13 +++++++++----
lang/polyml/PLIST | 4 +++-
lang/polyml/distinfo | 11 ++++++-----
lang/polyml/patches/patch-buildpolyc | 16 ++++++++++++++++
lang/polyml/patches/patch-libpolyml_elfexport.cpp | 10 +++++-----
5 files changed, 39 insertions(+), 15 deletions(-)
diffs (104 lines):
diff -r deaa8c3cf142 -r 76c7c23aa853 lang/polyml/Makefile
--- a/lang/polyml/Makefile Sun Dec 15 14:33:41 2013 +0000
+++ b/lang/polyml/Makefile Sun Dec 15 18:35:22 2013 +0000
@@ -1,7 +1,7 @@
-# $NetBSD: Makefile,v 1.8 2012/10/08 14:34:06 asau Exp $
+# $NetBSD: Makefile,v 1.9 2013/12/15 18:35:22 asau Exp $
-DISTNAME= polyml.5.5
-PKGNAME= polyml-5.5
+DISTNAME= polyml.5.5.1
+PKGNAME= polyml-5.5.1
CATEGORIES= lang
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE:=polyml/}
@@ -10,7 +10,6 @@
COMMENT= Poly/ML is an implementation of Standard ML
# ONLY_FOR_PLATFORM= *-*-i386 *-*-x86_64 *-*-sparc *-*-powerpc
-# Dumps core on NetBSD/amd64
GNU_CONFIGURE= yes
CONFIGURE_ARGS= --with-system-libffi
@@ -18,6 +17,12 @@
USE_LANGUAGES= c c++
TEST_TARGET= tests
+SUBST_CLASSES+= fix-rpath-flag
+SUBST_STAGE.fix-rpath-flag= pre-configure
+SUBST_MESSAGE.fix-rpath-flag= Fixing RPATH flag.
+SUBST_FILES.fix-rpath-flag= buildpolyc
+SUBST_SED.fix-rpath-flag= -e 's:@COMPILER_RPATH_FLAG@:${COMPILER_RPATH_FLAG}:g'
+
.include "options.mk"
.include "../../devel/libffi/buildlink3.mk"
diff -r deaa8c3cf142 -r 76c7c23aa853 lang/polyml/PLIST
--- a/lang/polyml/PLIST Sun Dec 15 14:33:41 2013 +0000
+++ b/lang/polyml/PLIST Sun Dec 15 18:35:22 2013 +0000
@@ -1,7 +1,9 @@
-@comment $NetBSD: PLIST,v 1.1.1.1 2009/03/20 21:12:51 asau Exp $
+@comment $NetBSD: PLIST,v 1.2 2013/12/15 18:35:22 asau Exp $
bin/poly
+bin/polyc
bin/polyimport
lib/libpolymain.la
lib/libpolyml.la
man/man1/poly.1
+man/man1/polyc.1
man/man1/polyimport.1
diff -r deaa8c3cf142 -r 76c7c23aa853 lang/polyml/distinfo
--- a/lang/polyml/distinfo Sun Dec 15 14:33:41 2013 +0000
+++ b/lang/polyml/distinfo Sun Dec 15 18:35:22 2013 +0000
@@ -1,6 +1,7 @@
-$NetBSD: distinfo,v 1.4 2012/10/08 14:33:32 asau Exp $
+$NetBSD: distinfo,v 1.5 2013/12/15 18:35:22 asau Exp $
-SHA1 (polyml.5.5.tar.gz) = 9b308d3ac69316d1fcb0f6ac5f9b9e2d2390d511
-RMD160 (polyml.5.5.tar.gz) = a2daf4230e7643c1febb455dea0c4f5682096d63
-Size (polyml.5.5.tar.gz) = 5504389 bytes
-SHA1 (patch-libpolyml_elfexport.cpp) = b32d52ea2a0b00b15cab1ec3aff0dac84add1d56
+SHA1 (polyml.5.5.1.tar.gz) = f5a0d289eb0a891af5ac6e897ccc7718ccf32d89
+RMD160 (polyml.5.5.1.tar.gz) = 504a9e8c064355bcee638a3735f7e97b3f92d03e
+Size (polyml.5.5.1.tar.gz) = 5465794 bytes
+SHA1 (patch-buildpolyc) = 9106912954a05355f7eab3b8a531bc016a85ac6c
+SHA1 (patch-libpolyml_elfexport.cpp) = 7291a7a1410651bee00662feb5f8d74337c14f3a
diff -r deaa8c3cf142 -r 76c7c23aa853 lang/polyml/patches/patch-buildpolyc
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/polyml/patches/patch-buildpolyc Sun Dec 15 18:35:22 2013 +0000
@@ -0,0 +1,16 @@
+$NetBSD: patch-buildpolyc,v 1.1 2013/12/15 18:35:23 asau Exp $
+
+--- buildpolyc.orig 2013-08-03 12:23:37.000000000 +0000
++++ buildpolyc
+@@ -15,9 +15,9 @@ link()
+ {
+ if [ X"$2" = "X" ]
+ then
+- ${LINK} ${EXTRALDFLAGS} $1 -L${LIBDIR} -lpolymain -lpolyml ${LIBS}
++ ${LINK} ${EXTRALDFLAGS} $1 -L${LIBDIR} @COMPILER_RPATH_FLAG@${LIBDIR} -lpolymain -lpolyml ${LIBS}
+ else
+- ${LINK} ${EXTRALDFLAGS} $1 -o $2 -L${LIBDIR} -lpolymain -lpolyml ${LIBS}
++ ${LINK} ${EXTRALDFLAGS} $1 -o $2 -L${LIBDIR} @COMPILER_RPATH_FLAG@{LIBDIR} -lpolymain -lpolyml ${LIBS}
+ fi
+ }
+
diff -r deaa8c3cf142 -r 76c7c23aa853 lang/polyml/patches/patch-libpolyml_elfexport.cpp
--- a/lang/polyml/patches/patch-libpolyml_elfexport.cpp Sun Dec 15 14:33:41 2013 +0000
+++ b/lang/polyml/patches/patch-libpolyml_elfexport.cpp Sun Dec 15 18:35:22 2013 +0000
@@ -1,10 +1,10 @@
-$NetBSD: patch-libpolyml_elfexport.cpp,v 1.1 2012/03/22 20:48:45 asau Exp $
+$NetBSD: patch-libpolyml_elfexport.cpp,v 1.2 2013/12/15 18:35:23 asau Exp $
---- libpolyml/elfexport.cpp.orig 2010-04-14 22:13:42.000000000 +0000
+--- libpolyml/elfexport.cpp.orig 2013-06-11 11:13:52.000000000 +0000
+++ libpolyml/elfexport.cpp
-@@ -62,6 +62,13 @@
- #ifdef HAVE_SYS_ELF_386_H
- #include <sys/elf_386.h>
+@@ -65,6 +65,13 @@
+ #ifdef HAVE_SYS_ELF_AMD64_H
+ #include <sys/elf_amd64.h>
#endif
+#if defined(__NetBSD__) && defined(HOSTARCHITECTURE_X86_64)
+#include <i386/elf_machdep.h>
Home |
Main Index |
Thread Index |
Old Index