Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 11 Aug 2018 19:20:06 +0000 (UTC)
From:      Piotr Pawel Stefaniak <pstef@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r337651 - head/usr.bin/indent
Message-ID:  <201808111920.w7BJK68P008635@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: pstef
Date: Sat Aug 11 19:20:06 2018
New Revision: 337651
URL: https://svnweb.freebsd.org/changeset/base/337651

Log:
  indent(1): revert r334640 and r334632
  
  While STACKSIZE macro is indeed problematic on some systems, the commits
  were wrong to shrink il[] and cstk[], because they need to be of the same
  size as p_stack[] as they're accessed with the same index ps.tos.

Modified:
  head/usr.bin/indent/indent_globs.h
  head/usr.bin/indent/parse.c

Modified: head/usr.bin/indent/indent_globs.h
==============================================================================
--- head/usr.bin/indent/indent_globs.h	Sat Aug 11 17:52:58 2018	(r337650)
+++ head/usr.bin/indent/indent_globs.h	Sat Aug 11 19:20:06 2018	(r337651)
@@ -234,11 +234,13 @@ int         inhibit_formatting;	/* true if INDENT OFF 
 int         suppress_blanklines;/* set iff following blanklines should be
 				 * suppressed */
 
+#define	STACKSIZE 256
+
 struct parser_state {
     int         last_token;
-    int         p_stack[256];	/* this is the parsers stack */
-    int         il[64];		/* this stack stores indentation levels */
-    float       cstk[32];	/* used to store case stmt indentation levels */
+    int         p_stack[STACKSIZE];	/* this is the parsers stack */
+    int         il[STACKSIZE];	/* this stack stores indentation levels */
+    float       cstk[STACKSIZE];/* used to store case stmt indentation levels */
     int         box_com;	/* set to true when we are in a "boxed"
 				 * comment. In that case, the first non-blank
 				 * char should be lined up with the / in / followed by * */

Modified: head/usr.bin/indent/parse.c
==============================================================================
--- head/usr.bin/indent/parse.c	Sat Aug 11 17:52:58 2018	(r337650)
+++ head/usr.bin/indent/parse.c	Sat Aug 11 19:20:06 2018	(r337651)
@@ -42,12 +42,10 @@ static char sccsid[] = "@(#)parse.c	8.1 (Berkeley) 6/6
 #endif
 
 #include <sys/cdefs.h>
-#include <sys/param.h>
 __FBSDID("$FreeBSD$");
 
 #include <err.h>
 #include <stdio.h>
-
 #include "indent_globs.h"
 #include "indent_codes.h"
 #include "indent.h"
@@ -211,7 +209,7 @@ parse(int tk) /* tk: the code for the construct scanne
 
     }				/* end of switch */
 
-    if (ps.tos >= (int)nitems(ps.p_stack) - 1)
+    if (ps.tos >= STACKSIZE - 1)
 	errx(1, "Parser stack overflow");
 
     reduce();			/* see if any reduction can be done */



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201808111920.w7BJK68P008635>