From d8ef4ce78b8db35158e8d30028ddd7db5f0f11f4 Mon Sep 17 00:00:00 2001 From: dholland Date: Mon, 14 Jul 2008 04:21:39 +0000 Subject: Update lang/snobol to 1.1. Note that the tcl bindings are not (yet) built. Next time... pkgsrc changes not trivial but should be invisible. Changelog: Changes since 1.0 release; ========================= Added new (experimental) builtin function groups: "DBM" -- "ndbm" keyed database access "COM" -- COM/OLE Automation on Win32 "STCL" -- SNOBOL/Tcl interface (optional) New library "dynamic.sno" to help compile/link dynamicly loadable extensions. Added HTTP.POST function to http.sno Handle environments where pointers can have high order bit set Linux 2.6 kernels in Fedora Core, SuSE 10 distributions Avoid broken "install" utilities autoconf compatibility: Honor CC, CFLAGS, CPPFLAGS, LDFLAGS, DESTDIR environment variables. Fix compilation on pre-panther OSX Fix second argument to DEFINE(): was not case folded! Fix backtracking over unevaluated expressions Source &FILE and &LINE shown in TRACE output Experimental: GC stats & tracing (-g on command line, >RACE keyword) Completed support for "memory I/O" when CSNOBOL4 used as a library! Added "PREDICATE" and "SYSPRED" return types in wrapper.sno Changes since 0.99.44 release; ============================= Added snolib(3) man page for SNOBOL4 library routines Treat all bytes with 8th bit set as ALPHA on ASCII systems allows UTF-8 encoded characters, and national character sets to used in labels and identifiers! command line: -S option to enlarge interpreter stack configure: added --mandir & --bindir IPv6 Support (both client and server) bi-directional "pipe" I/O on systems with sockets "privileged" port binding for UDP Lots of cleanup! DJGPP (DOS gcc) fixes default to -O3 with gcc add C prototypes for all functions (function declarations still "K&R" style) MINGW (Win32 gcc) fixes Fix LOAD() on Darwin (MacOS X) Fix timing script on Debian Ported to HP-UX/IA64 VMS: LOAD() support (not tested) Compilation on VMS7.3 support magic pathnames "/dev/null" and "/dev/tty" Win32: native (low overhead) support for character console I/O support magic pathnames "/dev/null" and "/dev/tty" fixed UDP I/O Fix for parallel make (GNU make, BSD make) Compilation under MS Visual Studio .NET 2003 Make struct descr packable (BITFIELDS_SAME_TYPE) Check for oversize integer constants (ERANGE from strtol()) Changes since 0.99.4 release; ============================ Command line: -d (dynamic region size) and -M (pattern match stack size) now take values in descriptors -v shows CSNOBOL4 version Increased default dynamic space to 64K descriptors Fix faulty lexical comparison function optimzations for null string Performance improvments; New string hash function (reduced both compilation and run time of genc.sno by 5%) Optimized most common case (CONTIN actions) in "stream" operation used for lexical analysis. (reduced compilation time of genc.sno by 8%) Merged all scanner (pattern matching) functions into single C function (eliminates mutual recursion, stack overflows) genc runtime reduced 15% atn.sno runtime reduced by 63%!! (2.7x faster) worst case (4096 char string) reduced 69% (4.8x faster) snocone self-compile runtime reduced 5% Made pattern building functions (lib/pat.c) inlinable (8% reduction in genc.sno compile time) Eliminate space padding on lines read by compiler (reduced genc.sno compile time by 65%) Raised default C compiler optimization levels Default &MAXLNGTH to largest possible string Documentation: README file describes available includes Include PDF of manual page Implement fatal "Output error" for output, ENDFILE() errors Configuration script re-write; Eliminate static config files & autoconf script configure generates config.m4 and config.h (with all defines) for use by loadable functions New configuration options; **** see "INSTALL" file for more information **** --add-define= Add a #define to config.h (visible to external functions) --double EXPERIMENTAL option to use C "double" for SNOBOL4 REAL data type --fast Architecture specific optimizations on native compilers --longlong EXPERIMENTAL!! try to use C "long long" (64-bit integer) for INTEGER datatype when longs/pointers are only 32-bits (ILP32 data model). --lp64 Request use of 64-bit long/pointer data model if available on this architecture, and not the default. --no-opt Compile without optimization New SNOBOL library files (see README); compatibility libraries: fence.sno, logic.sno, not.sno spitbol.sno, snobol4+.sno HOST() function codes: host.sno URL (http:, ftp:, file:) access functions Use large files (64-bit offsets) where available. Allows access and creation of files larger than 2GB New functions; FUNCTION() -- predicate to test if a function is defined ** EXPERIMENTAL ** LABEL() -- predicate to test if a label is defined idea from Steve Duff's version of Macro SPITBOL ORD() -- inverse of CHAR() SERV_LISTEN() -- act as TCP server SSET() -- scaled SET() allow large files when INTEGER is 32bits VDIFFER() -- returns first arg if two arguments DIFFER() idea from Steve Duff's version of Macro SPITBOL Extended HOST() functions (see host.sno) for system diagnosis HOST() function will accept REAL or integer encoded STRING args TIME() function now returns REAL datatype allows both better resolution (for small values) and larger range. Using 32-bit floats, runtimes larger than four and a half hours will lose resolution. Statistics reports compiler and execution times as REAL numbers Average statement runtime reported in microseconds (us). Allow a REAL any place an INTEGER is required (from SNOBOL4+) Contexts include TABLE(), ITEM(), array indices, INPUT(), OUTPUT(), SET(), keyword values, CHAR(), RPAD(), LPAD(), FIELD(), COLLECT(), DUMP(), DUPL(), OPSYN(), and SUBSTR() load.h updates; all RETxxx macros safe in any context RETSTR() takes single argument, allows NULL pointer RETSTR2() has old RETSTR() functionality RETINT() and RETREAL() always set return data type. All include files needed to build loadable functions installed in SNOLIB directory Include BSD tsort program; allow builds from scratch on platforms with GNU tsort (Linux, Cygwin) New ports; Ported to Darwin (MacOS X) Ported to Cygwin (http://cygwin.com), a free Unix emulation environment for Windows. Attempt at native Win32 port Updated Borland C port Updated VMS port; pipe open support, attempt at tty support --- lang/snobol/Makefile | 39 +++++++++++++----------- lang/snobol/PLIST | 41 +++++++++++++++++++++---- lang/snobol/distinfo | 15 ++++------ lang/snobol/patches/patch-ab | 71 +++++++------------------------------------- lang/snobol/patches/patch-ac | 12 -------- lang/snobol/patches/patch-ad | 30 ------------------- lang/snobol/patches/patch-ae | 10 ------- lang/snobol/patches/patch-af | 12 -------- lang/snobol/patches/patch-ag | 12 -------- 9 files changed, 74 insertions(+), 168 deletions(-) delete mode 100644 lang/snobol/patches/patch-ac delete mode 100644 lang/snobol/patches/patch-ad delete mode 100644 lang/snobol/patches/patch-ae delete mode 100644 lang/snobol/patches/patch-af delete mode 100644 lang/snobol/patches/patch-ag (limited to 'lang/snobol') diff --git a/lang/snobol/Makefile b/lang/snobol/Makefile index 4bb33118ef1..d0d61c539c8 100644 --- a/lang/snobol/Makefile +++ b/lang/snobol/Makefile @@ -1,10 +1,11 @@ -# $NetBSD: Makefile,v 1.20 2008/03/04 16:38:13 jlam Exp $ +# $NetBSD: Makefile,v 1.21 2008/07/14 04:21:39 dholland Exp $ # -DISTNAME= snobol-0.99.4 -PKGREVISION= 2 +DISTNAME= snobol4-1.1 +PKGNAME= snobol-1.1 CATEGORIES= lang -MASTER_SITES= ftp://ftp.snobol4.com/ \ +MASTER_SITES= ftp://ftp.ultimate.com/snobol/ +SITES.vanilla.zip= ftp://ftp.snobol4.com/ \ ftp://ftp.snobol4.org/snobol/old/ DISTFILES= vanilla.zip ${DISTNAME}${EXTRACT_SUFX} @@ -12,16 +13,24 @@ MAINTAINER= pkgsrc-users@NetBSD.org HOMEPAGE= http://www.snobol4.org/csnobol4/curr/ COMMENT= Macro implementation of SNOBOL4 in C -BUILD_DEPENDS+= unzip-[0-9]*:../../archivers/unzip - PKG_DESTDIR_SUPPORT= user-destdir EXTRACT_ONLY= ${DISTNAME}${EXTRACT_SUFX} -BUILD_TARGET= it +SUBST_CLASSES+= snobol-config +SUBST_STAGE.snobol-config= post-patch +SUBST_FILES.snobol-config= Makefile +SUBST_SED.snobol-config+= -e s\|M4=m4\|M4=${TOOLS_PATH.m4:Q}\| + +HAS_CONFIGURE=yes +CONFIGURE_ARGS+=--prefix=${PREFIX} +# not yet +#CONFIGURE_ARGS+=--with-tcl +#CONFIGURE_ARGS+=--with-tk -USE_CONFIGURE= NO -USE_TOOLS+= gzip m4 +BUILD_TARGET= all pv + +USE_TOOLS+= gzip m4 unzip INSTALLATION_DIRS= bin ${PKGMANDIR}/man1 MAKE_JOBS_SAFE= NO @@ -31,15 +40,11 @@ post-build: unzip -p -opaaqqLC ${WRKSRC}/pm.exe >> ${WRKSRC}/doc/tutorial ${GZIP_CMD} ${WRKSRC}/doc/tutorial -do-install: - ${INSTALL_PROGRAM} ${WRKSRC}/xsnobol4 ${DESTDIR}${PREFIX}/bin/snobol4 - ${INSTALL_MAN} ${WRKSRC}/doc/snobol4.1 \ - ${DESTDIR}${PREFIX}/${PKGMANDIR}/man1 - ${INSTALL_DATA_DIR} ${DESTDIR}${PREFIX}/lib/snobol4 - cd ${WRKSRC} && ${INSTALL_DATA} snolib.a snolib/bq.sno \ - ${DESTDIR}${PREFIX}/lib/snobol4 +post-install: ${INSTALL_DATA_DIR} ${DESTDIR}${PREFIX}/share/doc/snobol4 - cd ${WRKSRC}/doc && ${INSTALL_DATA} load.doc design.doc tutorial.gz \ + cd ${WRKSRC} && ${INSTALL_DATA} README \ + ${DESTDIR}${PREFIX}/share/doc/snobol4 + cd ${WRKSRC}/doc && ${INSTALL_DATA} load.txt design.txt tutorial.gz \ ${DESTDIR}${PREFIX}/share/doc/snobol4 @${ECHO} '' @${ECHO} '***********************************************************' diff --git a/lang/snobol/PLIST b/lang/snobol/PLIST index 915e0df0056..c8134282886 100644 --- a/lang/snobol/PLIST +++ b/lang/snobol/PLIST @@ -1,10 +1,41 @@ -@comment $NetBSD: PLIST,v 1.1 2001/11/01 00:24:59 zuntum Exp $ +@comment $NetBSD: PLIST,v 1.2 2008/07/14 04:21:39 dholland Exp $ bin/snobol4 -man/man1/snobol4.1 -lib/snobol4/snolib.a +bin/snobol4-1.1 lib/snobol4/bq.sno -share/doc/snobol4/load.doc -share/doc/snobol4/design.doc +lib/snobol4/chars.sno +lib/snobol4/config.h +lib/snobol4/dt.h +lib/snobol4/dynamic.sno +lib/snobol4/equ.h +lib/snobol4/fence.sno +lib/snobol4/file.sno +lib/snobol4/ftp.sno +lib/snobol4/h.h +lib/snobol4/host.sno +lib/snobol4/http.sno +lib/snobol4/load.h +lib/snobol4/logic.sno +lib/snobol4/macros.h +lib/snobol4/ndbm.sno +lib/snobol4/not.sno +lib/snobol4/serv.sno +lib/snobol4/smtp.sno +lib/snobol4/snobol4+.sno +lib/snobol4/snotypes.h +lib/snobol4/spitbol.sno +lib/snobol4/stcl.sno +lib/snobol4/tcp.sno +lib/snobol4/unique.sno +lib/snobol4/url.sno +lib/snobol4/utf.sno +lib/snobol4/wrapper.sno +man/man1/snobol4.1 +man/man3/snobol4dbm.3 +man/man3/snobol4tcl.3 +man/man3/snolib.3 +share/doc/snobol4/README +share/doc/snobol4/load.txt +share/doc/snobol4/design.txt share/doc/snobol4/tutorial.gz @dirrm lib/snobol4 @dirrm share/doc/snobol4 diff --git a/lang/snobol/distinfo b/lang/snobol/distinfo index 245dc640770..26f0635b7da 100644 --- a/lang/snobol/distinfo +++ b/lang/snobol/distinfo @@ -1,15 +1,10 @@ -$NetBSD: distinfo,v 1.7 2007/12/22 21:40:13 tnn Exp $ +$NetBSD: distinfo,v 1.8 2008/07/14 04:21:39 dholland Exp $ -SHA1 (snobol-0.99.4.tar.gz) = 7c64efac165b83665b454c245e3cbec19d448a2e -RMD160 (snobol-0.99.4.tar.gz) = 58b6323930241d992abf7edd13243068ce6304ce -Size (snobol-0.99.4.tar.gz) = 388020 bytes +SHA1 (snobol4-1.1.tar.gz) = 33517d66967615329ec071e9d3dd8125a974ec27 +RMD160 (snobol4-1.1.tar.gz) = 53a903ff051b0b9acd2dbff5b7f3c79389af6c01 +Size (snobol4-1.1.tar.gz) = 677333 bytes SHA1 (vanilla.zip) = e0d3aa420192738c1b3d59a022860683fba99504 RMD160 (vanilla.zip) = a728aef1a1606dadeed7fde0c5826f46c342ac12 Size (vanilla.zip) = 212373 bytes SHA1 (patch-aa) = 02b759eb25bd46678d96eb281247ae326822d8f4 -SHA1 (patch-ab) = 5ee785b285011b7954967f4a4e53293739d35844 -SHA1 (patch-ac) = fa50c033004211d50db5b50eb71c542aaa3c6c35 -SHA1 (patch-ad) = 8e58fd6aefae7df29c6f7ab2cadf55dd58763870 -SHA1 (patch-ae) = 627672573eb37c7df6c4b84ef765ea777b25b11a -SHA1 (patch-af) = c3831fdc0d172df9f2032c997f9169b345a6e2a8 -SHA1 (patch-ag) = 9f87472c11a7f3bfbfa818ba9cbd526598351b3d +SHA1 (patch-ab) = f9d5017a5f65fbafa8c483ea84ec9ec6ff2a4169 diff --git a/lang/snobol/patches/patch-ab b/lang/snobol/patches/patch-ab index f431d3b032f..1d1b385d123 100644 --- a/lang/snobol/patches/patch-ab +++ b/lang/snobol/patches/patch-ab @@ -1,63 +1,14 @@ -$NetBSD: patch-ab,v 1.3 2004/07/10 21:27:46 wiz Exp $ +$NetBSD: patch-ab,v 1.4 2008/07/14 04:21:39 dholland Exp $ ---- lib/bsd/mstime.c.orig Wed Oct 30 12:39:40 1996 -+++ lib/bsd/mstime.c Thu Jan 25 07:08:41 2001 -@@ -12,11 +12,56 @@ - * (and you don't need to know HZ) - */ +--- Makefile2.m4.orig 2005-12-06 21:10:59.000000000 -0500 ++++ Makefile2.m4 2008-07-14 00:02:37.000000000 -0400 +@@ -537,7 +537,8 @@ + # generated SNOLIB files (host.sno generated at top level) + GENSNOLIB=host.sno -+/* Added by refling@comet.lbl.gov to compensate for the fact that the usec -+ value can go backwards within the same sec on NetBSD. Problem has been -+ noted on sparc and i386. It really only appears in the test routine -+ where times are differenced, causing negative numbers to be generated. -+ This WILL cause the build to fail consistently on my sparc LX, but not -+ on the i386, even though the problem can be demonstrated there. See -+ NetBSD PR bin/10201. -+ -+ The simple solution here is to have a persistent variable, and if the -+ usec value returned from getrusage() is LESS than the previous one -+ (stored in the persistent variable), use the previous one. This is -+ only when the second counter is the same between the previous and -+ current usec. This will make time stand still, but at least it -+ won't go backwards! -+ -+ This could also be added to the definition of the NetBSD getrusage() -+ function to prevent it from returning bogus values in the first place, -+ if the real cause of the problem can't be tracked down. -+ -+ Note that the patch to snobol4 (in this file) will not need to be -+ changed even if/when getrusage() is ultimately fixed. The only expense -+ is a few extra numerical comparisons. Typically, one doesn't take time -+ measurements too often. */ -+ -+static long prev_sec = 0; -+static long prev_usec = 0; -+ - int_t - mstime() { - struct rusage ru; -+ long cur_usec, cur_sec; +-SNOLIB_FILES=snolib/*.sno $(INSTALL_H) doc/load.txt README $(GENSNOLIB) ++SNOLIB_FILES=snolib/*.sno $(INSTALL_H) $(GENSNOLIB) ++# doc/load.txt README # installed by package makefile - getrusage( RUSAGE_SELF, &ru ); /* XXX check return? */ -- return(ru.ru_utime.tv_sec * 1000 + -- ru.ru_utime.tv_usec / 1000); -+ cur_usec = ru.ru_utime.tv_usec; -+ cur_sec = ru.ru_utime.tv_sec; -+ if (prev_usec > cur_usec && prev_sec == cur_sec) { -+ cur_usec = prev_usec; -+// prev_sec = cur_sec; /* this is redundant in this case, since == */ -+// prev_usec = cur_usec; /* this is also redundant */ -+// system("echo a >> /tmp/caught_problem"); -+ } -+ else { -+ prev_sec = cur_sec; -+ prev_usec = cur_usec; -+ } -+ return(cur_sec * 1000 + -+ cur_usec / 1000); -+ -+// this is what it was.... -+// getrusage( RUSAGE_SELF, &ru ); /* XXX check return? */ -+// return(ru.ru_utime.tv_sec * 1000 + -+// ru.ru_utime.tv_usec / 1000); - } + VERS=`./pv` + install: snobol4 pv diff --git a/lang/snobol/patches/patch-ac b/lang/snobol/patches/patch-ac deleted file mode 100644 index fdec798ce07..00000000000 --- a/lang/snobol/patches/patch-ac +++ /dev/null @@ -1,12 +0,0 @@ -$NetBSD: patch-ac,v 1.2 2004/07/10 21:27:46 wiz Exp $ - ---- configure.orig Fri Jul 18 14:43:30 1997 -+++ configure Thu Jan 25 07:08:41 2001 -@@ -1,6 +1,6 @@ - #!/bin/sh - --if autoconf "$@" > config.m4.tmp; then -+if ./autoconf "$@" > config.m4.tmp; then - rm -f config.m4 - mv config.m4.tmp config.m4 - else diff --git a/lang/snobol/patches/patch-ad b/lang/snobol/patches/patch-ad deleted file mode 100644 index 5e52c11c689..00000000000 --- a/lang/snobol/patches/patch-ad +++ /dev/null @@ -1,30 +0,0 @@ -$NetBSD: patch-ad,v 1.3 2004/07/10 21:28:21 wiz Exp $ - ---- Makefile2.m4.orig 1997-08-07 07:34:47.000000000 +0200 -+++ Makefile2.m4 -@@ -48,13 +48,13 @@ SNOLIB_A=snolib.a - SNOLIB_FILE=snolib.a - - # directory name for default SNOLIB (used by -INCLUDE and LOAD()) --SNOLIB_DIR=/usr/local/lib/snobol4 -+SNOLIB_DIR=${PREFIX}/lib/snobol4 - - # default name for installed binary --BINDEST=/usr/local/bin/snobol4 -+BINDEST=${PREFIX}/bin/snobol4 - - # default name for installed man page --MANDEST=/usr/local/man/man1/snobol4.1 -+MANDEST=${PREFIX}/man/man1/snobol4.1 - - ######## - # default lib source files -@@ -142,7 +142,7 @@ include(config.m4) - # after local config - - # NOTE: NOT named CPPFLAGS; some versions of make include CPPFLAGS in cc cmd --MYCPPFLAGS=-I./[include] -I. _CPPFLAGS -+MYCPPFLAGS=-DUSE_STDARG_H -I./[include] -I. _CPPFLAGS - - COPT=[]_OPT - diff --git a/lang/snobol/patches/patch-ae b/lang/snobol/patches/patch-ae deleted file mode 100644 index 33cf1875a38..00000000000 --- a/lang/snobol/patches/patch-ae +++ /dev/null @@ -1,10 +0,0 @@ -$NetBSD: patch-ae,v 1.1 2006/01/11 21:51:34 joerg Exp $ - ---- isnobol4.c.orig 2006-01-11 21:39:49.000000000 +0000 -+++ isnobol4.c -@@ -1,3 +1,5 @@ -+#include -+ - /* generated by genc.sno on 08/06/1997 01:52:51 */ - - #define INLINING diff --git a/lang/snobol/patches/patch-af b/lang/snobol/patches/patch-af deleted file mode 100644 index 3de0626d9c5..00000000000 --- a/lang/snobol/patches/patch-af +++ /dev/null @@ -1,12 +0,0 @@ -$NetBSD: patch-af,v 1.1 2007/12/22 21:40:13 tnn Exp $ - ---- lib/bsd/inet.c.orig 1997-07-12 00:33:32.000000000 +0200 -+++ lib/bsd/inet.c -@@ -10,6 +10,7 @@ - #include - - #include "h.h" /* TRUE/FALSE */ -+#include "snotypes.h" - #include "macros.h" /* bcopy */ - - #ifndef INADDR_NONE diff --git a/lang/snobol/patches/patch-ag b/lang/snobol/patches/patch-ag deleted file mode 100644 index e27d1273d76..00000000000 --- a/lang/snobol/patches/patch-ag +++ /dev/null @@ -1,12 +0,0 @@ -$NetBSD: patch-ag,v 1.1 2007/12/22 21:40:13 tnn Exp $ - ---- lib/bsd/dynamic.c.orig 1997-02-13 07:31:42.000000000 +0100 -+++ lib/bsd/dynamic.c -@@ -2,6 +2,7 @@ - - /* allocate dynamic region on BSD */ - -+#include - #include - - char *malloc(); -- cgit v1.2.3