[comp.sources.bugs] gawk-2.13 patch1

david@cs.dal.ca (David Trueman) (06/27/91)

This is patch1 for gawk-2.13.  Mostly it just fixes a few portability
problems, but it also fixes a serious bug in division and one in
the modulus implementation.  Change directory to the gawk source
and then apply with patch -p1

diff -cr gawk-2.13.0/CHANGES ./CHANGES
*** gawk-2.13.0/CHANGES	Thu Jun 20 22:03:28 1991
--- ./CHANGES	Wed Jun 26 22:42:08 1991
***************
*** 1,3 ****
--- 1,27 ----
+ Changes from 2.13.0 to 2.13.1
+ -----------------------------
+ 
+ More configs and PORTS.
+ 
+ Fixed bug wherein a simple division produced an erroneous FPE, caused by
+   the Cray division workaround -- that code is now #ifdef'd only for
+   Cray *and* fixed.
+ 
+ Fixed bug in modulus implementation -- it was very close to the above
+   code, so I noticed it.
+ 
+ Fixed portability problem with limits.h in missing.c
+ 
+ Fixed portability problem with tzname and daylight -- define TZNAME_MISSING
+   if strftime() is missing and tzname is also.
+ 
+ Better support for Latin-1 character set.
+ 
+ Fixed portability problem in test Makefile.
+ 
+ Updated PROBLEMS file.
+ 
+ =============================== gawk-2.13 released =========================
  Changes from 2.12.42 to 2.12.43
  -------------------------------
  
diff -cr gawk-2.13.0/PORTS ./PORTS
*** gawk-2.13.0/PORTS	Sat Jun 22 21:33:04 1991
--- ./PORTS	Wed Jun 26 22:25:21 1991
***************
*** 3,9 ****
  
  Sun 4/490 running 4.1
  NeXT running 2.0
! DECstation 3100 running Ultrix 4.0
  AtariST (16-bit ints, gcc compiler, byacc, running under TOS)
  ESIX V.3.2 Rev D (== System V Release 3.2), the 386.  compiler was gcc + bison
  IBM RS/6000 (see README.rs6000)
--- 3,9 ----
  
  Sun 4/490 running 4.1
  NeXT running 2.0
! DECstation 3100 running Ultrix 4.0 or Ultrix 3.1 (different config)
  AtariST (16-bit ints, gcc compiler, byacc, running under TOS)
  ESIX V.3.2 Rev D (== System V Release 3.2), the 386.  compiler was gcc + bison
  IBM RS/6000 (see README.rs6000)
***************
*** 12,17 ****
  Sequent Balance running Dynix V3.1
  Cray Y-MP8 running Unicos 6.0.11
  Cray 2 running Unicos 6.1 (modulo trailing zeroes in chem)
! VMS
  MSDOS - Microsoft C 5.1, compiles and runs very simple testing
  CLOSE: 4.3reno
--- 12,17 ----
  Sequent Balance running Dynix V3.1
  Cray Y-MP8 running Unicos 6.0.11
  Cray 2 running Unicos 6.1 (modulo trailing zeroes in chem)
! VMS 5.x (should also work on 4.6 and 4.7)
  MSDOS - Microsoft C 5.1, compiles and runs very simple testing
  CLOSE: 4.3reno
diff -cr gawk-2.13.0/PROBLEMS ./PROBLEMS
*** gawk-2.13.0/PROBLEMS	Sun Nov 18 11:35:16 1990
--- ./PROBLEMS	Tue Jun 25 22:48:33 1991
***************
*** 1,11 ****
! This is a list of known problems in gawk 2.12.
  Hopefully they will all be fixed in the next major release of gawk.
  
! Please keep in mind that the code
! is still undergoing significant evolution.
  
! 1. The debugging code does not print redirection info.
  
! 2. Gawk's printf doesn't yet match the latest nawk's.
! 
! Arnold Robbins
--- 1,8 ----
! This is a list of known problems in gawk 2.13.
  Hopefully they will all be fixed in the next major release of gawk.
  
! Please keep in mind that the code is still undergoing significant evolution.
  
! 1. Gawk's error messages are not in GNU standard format (not emacs parseable).
  
! 2. Gawk's printf is probably still not POSIX compliant.
diff -cr gawk-2.13.0/awk.h ./awk.h
*** gawk-2.13.0/awk.h	Sat Jun  1 14:33:13 1991
--- ./awk.h	Wed Jun 26 22:13:00 1991
***************
*** 85,91 ****
  #include "protos.h"
  #endif	/* STDC_HEADERS */
  
! #ifdef ultrix
  extern char * getenv P((char *name));
  extern double atof P((char *s));
  #endif
--- 85,91 ----
  #include "protos.h"
  #endif	/* STDC_HEADERS */
  
! #if defined(ultrix) && !defined(Ultrix41)
  extern char * getenv P((char *name));
  extern double atof P((char *s));
  #endif
***************
*** 135,143 ****
  extern void vms_arg_fixup P((int *,char ***));
  #endif  /*VMS*/
  
! #ifdef MSDOS
! extern int errno;
! #endif	/* MSDOS */
  
  #define	GNU_REGEX
  #ifdef GNU_REGEX
--- 135,141 ----
  extern void vms_arg_fixup P((int *,char ***));
  #endif  /*VMS*/
  
! extern int errno;	/* not necessary on many systems, but it can't hurt */
  
  #define	GNU_REGEX
  #ifdef GNU_REGEX
diff -cr gawk-2.13.0/config/sunos40 ./config/sunos40
*** gawk-2.13.0/config/sunos40	Fri Apr 26 21:49:40 1991
--- ./config/sunos40	Wed Jun 26 22:04:16 1991
***************
*** 3,6 ****
--- 3,7 ----
  STRCASE_MISSING	1 
  STRERROR_MISSING	1 
  STRFTIME_MISSING	1 
+ TZNAME_MISSING	1
  NON_STD_SPRINTF	1 
diff -cr gawk-2.13.0/config/ultrix31 ./config/ultrix31
*** gawk-2.13.0/config/ultrix31	Fri Apr 26 21:53:32 1991
--- ./config/ultrix31	Mon Jun 24 16:02:44 1991
***************
*** 1,5 ****
! VAX running Ultrix 3.x
  HAVE_UNDERSCORE_SETJMP	1 
  STRERROR_MISSING	1 
  STRFTIME_MISSING	1 
  NON_STD_SPRINTF	1 
--- 1,6 ----
! DECstation or VAX running Ultrix 3.x
  HAVE_UNDERSCORE_SETJMP	1 
  STRERROR_MISSING	1 
  STRFTIME_MISSING	1 
  NON_STD_SPRINTF	1 
+ TZSET_MISSING	1
diff -cr gawk-2.13.0/config/ultrix41 ./config/ultrix41
*** gawk-2.13.0/config/ultrix41	Tue Jun 25 15:54:42 1991
--- ./config/ultrix41	Tue Jun 25 15:55:13 1991
***************
*** 0 ****
--- 1,3 ----
+ DECstation running Ultrix 4.1 (and 4.2??)
+ STDC_HEADERS	1 
+ Ultrix41	1
diff -cr gawk-2.13.0/config.h-dist ./config.h-dist
*** gawk-2.13.0/config.h-dist	Tue May 21 23:31:18 1991
--- ./config.h-dist	Wed Jun 26 22:03:43 1991
***************
*** 150,163 ****
  /* #define STRERROR_MISSING	1 */
  
  /*
-  * STRFTIME_MISSING
-  *
-  * Your system lacks the ANSI C strftime() routine for formatting
-  * broken down time values.
-  */
- /* #define STRFTIME_MISSING	1 */
- 
- /*
   * STRTOD_MISSING
   *
   * Your system does not have the strtod() routine for converting
--- 150,155 ----
***************
*** 174,179 ****
--- 166,179 ----
  /* #define STRTOL_MISSING	1 */
  
  /*
+  * STRFTIME_MISSING
+  *
+  * Your system lacks the ANSI C strftime() routine for formatting
+  * broken down time values.
+  */
+ /* #define STRFTIME_MISSING	1 */
+ 
+ /*
   * TZSET_MISSING
   *
   * If you have a 4.2 BSD vintage system, then the strftime() routine
***************
*** 183,188 ****
--- 183,196 ----
   * have tzset(), define this.
   */
  /* #define TZSET_MISSING	1 */
+ 
+ /*
+  * TZNAME_MISSING
+  *
+  * Some systems do not support the external variables tzname and daylight.
+  * If this is the case *and* strftime() is missing, define this.
+  */
+ /* #define TZNAME_MISSING	1 */
  
  /*
   * STDC_HEADERS
diff -cr gawk-2.13.0/eval.c ./eval.c
*** gawk-2.13.0/eval.c	Mon Jun  3 09:20:44 1991
--- ./eval.c	Wed Jun 26 22:49:03 1991
***************
*** 26,31 ****
--- 26,32 ----
  #include "awk.h"
  
  extern double pow P((double x, double y));
+ extern double modf P((double x, double *yp));
  
  static int eval_condition P((NODE *tree));
  static NODE *op_assign P((NODE *tree));
***************
*** 560,580 ****
  	case Node_quotient:
  		if (x2 == 0)
  			fatal("division by zero attempted");
  		/*
  		 * special case for integer division, put in for Cray
- 		 * but maybe someone else will benefit -- let's see
  		 */
! 		lx = (long) x1 / (long) x2;
  		if (lx * x2 == x1)
! 			return tmp_number((double) lx);
  		else
  			return tmp_number(x1 / x2);
  
  	case Node_mod:
  		if (x2 == 0)
  			fatal("division by zero attempted in mod");
! 		lx = (long) x1 / (long) x2;	/* assignment to long truncates */
! 		return tmp_number(x1 - lx * x2);
  
  	case Node_plus:
  		return tmp_number(x1 + x2);
--- 561,585 ----
  	case Node_quotient:
  		if (x2 == 0)
  			fatal("division by zero attempted");
+ #ifdef _CRAY
  		/*
  		 * special case for integer division, put in for Cray
  		 */
! 		lx2 = x2;
! 		if (lx2 == 0)
! 			return tmp_number(x1 / x2);
! 		lx = (long) x1 / lx2;
  		if (lx * x2 == x1)
! 			return tmp_number((AWKNUM) lx);
  		else
+ #endif
  			return tmp_number(x1 / x2);
  
  	case Node_mod:
  		if (x2 == 0)
  			fatal("division by zero attempted in mod");
! 		(void) modf(x1 / x2, &x);
! 		return tmp_number(x1 - x * x2);
  
  	case Node_plus:
  		return tmp_number(x1 + x2);
***************
*** 749,762 ****
  	case Node_assign_quotient:
  		if (rval == (AWKNUM) 0)
  			fatal("division by zero attempted in /=");
  		/*
  		 * special case for integer division, put in for Cray
- 		 * but maybe someone else will benefit -- let's see
  		 */
! 		ltemp = (long) lval / (long) rval;
  		if (ltemp * lval == rval)
! 			*lhs = make_number((double) ltemp);
  		else
  			*lhs = make_number(lval / rval);
  		break;
  
--- 754,771 ----
  	case Node_assign_quotient:
  		if (rval == (AWKNUM) 0)
  			fatal("division by zero attempted in /=");
+ #ifdef _CRAY
  		/*
  		 * special case for integer division, put in for Cray
  		 */
! 		ltemp = rval;
! 		if (ltemp == 0)
! 			*lhs = make_number(lval / rval);
! 		ltemp = (long) lval / ltemp;
  		if (ltemp * lval == rval)
! 			*lhs = make_number((AWKNUM) ltemp);
  		else
+ #endif
  			*lhs = make_number(lval / rval);
  		break;
  
***************
*** 763,771 ****
  	case Node_assign_mod:
  		if (rval == (AWKNUM) 0)
  			fatal("division by zero attempted in %=");
! 		ltemp = (long) lval / (long) rval;	/* assignment to long truncates */
! 		t1 = ltemp * rval;
! 		t2 = lval - t1;
  		*lhs = make_number(t2);
  		break;
  
--- 772,779 ----
  	case Node_assign_mod:
  		if (rval == (AWKNUM) 0)
  			fatal("division by zero attempted in %=");
! 		(void) modf(lval / rval, &t1);
! 		t2 = lval - rval * t1;
  		*lhs = make_number(t2);
  		break;
  
diff -cr gawk-2.13.0/missing/strcase.c ./missing/strcase.c
*** gawk-2.13.0/missing/strcase.c	Wed Nov 28 21:09:39 1990
--- ./missing/strcase.c	Wed Jun 26 22:35:39 1991
***************
*** 51,60 ****
  	'\250', '\251', '\252', '\253', '\254', '\255', '\256', '\257',
  	'\260', '\261', '\262', '\263', '\264', '\265', '\266', '\267',
  	'\270', '\271', '\272', '\273', '\274', '\275', '\276', '\277',
! 	'\300', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
  	'\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
! 	'\360', '\361', '\362', '\363', '\364', '\365', '\366', '\367',
! 	'\370', '\371', '\372', '\333', '\334', '\335', '\336', '\337',
  	'\340', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
  	'\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
  	'\360', '\361', '\362', '\363', '\364', '\365', '\366', '\367',
--- 51,60 ----
  	'\250', '\251', '\252', '\253', '\254', '\255', '\256', '\257',
  	'\260', '\261', '\262', '\263', '\264', '\265', '\266', '\267',
  	'\270', '\271', '\272', '\273', '\274', '\275', '\276', '\277',
! 	'\340', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
  	'\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
! 	'\360', '\361', '\362', '\363', '\364', '\365', '\366', '\327',
! 	'\370', '\371', '\372', '\373', '\374', '\375', '\376', '\337',
  	'\340', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
  	'\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
  	'\360', '\361', '\362', '\363', '\364', '\365', '\366', '\367',
diff -cr gawk-2.13.0/missing/strftime.c ./missing/strftime.c
*** gawk-2.13.0/missing/strftime.c	Tue Jun 18 15:16:56 1991
--- ./missing/strftime.c	Wed Jun 26 22:00:19 1991
***************
*** 44,50 ****
  static int weeknumber(const struct tm *timeptr, int firstweekday);
  #endif
  
! #ifndef MSDOS
  extern char *tzname[2];
  extern int daylight;
  #endif
--- 44,50 ----
  static int weeknumber(const struct tm *timeptr, int firstweekday);
  #endif
  
! #if !defined(MSDOS) && !defined(TZNAME_MISSING)
  extern char *tzname[2];
  extern int daylight;
  #endif
***************
*** 244,252 ****
  
  		case 'Z':	/* time zone name or abbrevation */
  			i = 0;
! 			if (daylight && timeptr->tm_isdst)
  				i = 1;
  			strcpy(tbuf, tzname[i]);
  			break;
  
  #ifdef SYSV_EXT
--- 244,260 ----
  
  		case 'Z':	/* time zone name or abbrevation */
  			i = 0;
! 			if (
! #ifndef TZNAME_MISSING
! 			    daylight &&
! #endif
! 			    timeptr->tm_isdst)
  				i = 1;
+ #ifdef TZNAME_MISSING
+ 			strcpy(tbuf, timeptr->tm_zone);
+ #else
  			strcpy(tbuf, tzname[i]);
+ #endif
  			break;
  
  #ifdef SYSV_EXT
diff -cr gawk-2.13.0/missing/strtol.c ./missing/strtol.c
*** gawk-2.13.0/missing/strtol.c	Thu May 30 23:24:12 1991
--- ./missing/strtol.c	Tue Jun 25 22:56:24 1991
***************
*** 15,20 ****
--- 15,27 ----
  handle several cases correctly.)
  */
  
+ #ifdef __STDC__
+ #include <limits.h>
+ #else
+ #define	LONG_MIN	(-0x80000000)	/* for 32-bit 2s-complement at least */
+ #define	LONG_MAX	0x7fffffff
+ #endif
+ 
  #if 0
  #include <limits.h>
  #include <ctype.h>
diff -cr gawk-2.13.0/missing.c ./missing.c
*** gawk-2.13.0/missing.c	Sun Jun  2 09:49:05 1991
--- ./missing.c	Tue Jun 25 15:33:21 1991
***************
*** 5,16 ****
  #include <stdio.h>
  #include <ctype.h>
  #include <errno.h>
- #ifdef sequent
- #define	LONG_MIN	(-1*0x7fffffff)	/* ?? */
- #define	LONG_MAX	0x7fffffff	/* ?? */
- #else
- #include <limits.h>
- #endif
  #ifndef VAXC
  #include <fcntl.h>
  #include <sys/types.h>
--- 5,10 ----
diff -cr gawk-2.13.0/patchlevel.h ./patchlevel.h
*** gawk-2.13.0/patchlevel.h	Sat Jun 22 21:30:46 1991
--- ./patchlevel.h	Wed Jun 26 23:01:10 1991
***************
*** 1 ****
! #define PATCHLEVEL	0
--- 1 ----
! #define PATCHLEVEL	1
diff -cr gawk-2.13.0/regex.c ./regex.c
*** gawk-2.13.0/regex.c	Thu May 30 23:24:12 1991
--- ./regex.c	Wed Jun 26 22:35:40 1991
***************
*** 123,128 ****
--- 123,134 ----
  
     for (c = '0'; c <= '9'; c++)
       re_syntax_table[c] = Sword;
+  
+    /* Add specific syntax for ISO Latin-1.  */
+    for (c = 0300; c <= 0377; c++)
+      re_syntax_table[c] = Sword;
+    re_syntax_table[0327] = 0;
+    re_syntax_table[0367] = 0;
  
     done = 1;
  }
-- 
{uunet watmath}!dalcs!david  or  david@cs.dal.ca