Source-Changes-HG archive

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

[src/trunk]: src/external/bsd/byacc Implement some more bison features (incom...



details:   https://anonhg.NetBSD.org/src/rev/a333c69f5241
branches:  trunk
changeset: 805487:a333c69f5241
user:      christos <christos%NetBSD.org@localhost>
date:      Sun Jan 04 01:34:20 2015 +0000

description:
Implement some more bison features (incomplete!!!)
This handles the mesa/gallium parser but the %error-verbose part needs a
little more work.

diffstat:

 external/bsd/byacc/dist/btyaccpar.c |    6 +-
 external/bsd/byacc/dist/defs.h      |   31 +++-
 external/bsd/byacc/dist/error.c     |   46 +++---
 external/bsd/byacc/dist/main.c      |    6 +-
 external/bsd/byacc/dist/mstring.c   |   18 +-
 external/bsd/byacc/dist/output.c    |   17 ++-
 external/bsd/byacc/dist/reader.c    |  230 +++++++++++++++++++++--------------
 external/bsd/byacc/dist/yaccpar.c   |    7 +-
 external/bsd/byacc/include/config.h |   11 +-
 9 files changed, 229 insertions(+), 143 deletions(-)

diffs (truncated from 1087 to 300 lines):

diff -r d478b5c9e149 -r a333c69f5241 external/bsd/byacc/dist/btyaccpar.c
--- a/external/bsd/byacc/dist/btyaccpar.c       Sun Jan 04 01:26:31 2015 +0000
+++ b/external/bsd/byacc/dist/btyaccpar.c       Sun Jan 04 01:34:20 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: btyaccpar.c,v 1.1.1.1 2015/01/03 22:58:23 christos Exp $       */
+/*     $NetBSD: btyaccpar.c,v 1.2 2015/01/04 01:34:20 christos Exp $   */
 
 /* This file generated automatically using
  * @Id: skel2c,v 1.3 2014/04/06 19:48:04 tom Exp @
@@ -451,6 +451,10 @@
     "        fprintf(stderr, \"%sdebug[<# of symbols on state stack>]\\n\", YYPREFIX);",
     "#endif",
     "",
+    0
+};
+
+const char *const body_3[] = {
 #if defined(YYBTYACC)
     "#if YYBTYACC",
     "    yyps = yyNewState(0); if (yyps == 0) goto yyenomem;",
diff -r d478b5c9e149 -r a333c69f5241 external/bsd/byacc/dist/defs.h
--- a/external/bsd/byacc/dist/defs.h    Sun Jan 04 01:26:31 2015 +0000
+++ b/external/bsd/byacc/dist/defs.h    Sun Jan 04 01:34:20 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: defs.h,v 1.8 2015/01/03 23:22:52 christos Exp $        */
+/*     $NetBSD: defs.h,v 1.9 2015/01/04 01:34:20 christos Exp $        */
 
 #if HAVE_NBTOOL_CONFIG_H
 #include "nbtool_config.h"
@@ -123,10 +123,13 @@
 #define LEX_PARAM 14
 #define POSIX_YACC 15
 #define TOKEN_TABLE 16
+#define ERROR_VERBOSE 17
+#define XXXDEBUG 18
 
 #if defined(YYBTYACC)
-#define LOCATIONS 17
-#define DESTRUCTOR 18
+#define LOCATIONS 19
+#define DESTRUCTOR 20
+#define INITIAL_ACTION 21
 #endif
 
 /*  symbol classes  */
@@ -292,10 +295,12 @@
 extern int exit_code;
 extern int pure_parser;
 extern int token_table;
+extern int error_verbose;
 #if defined(YYBTYACC)
 extern int locations;
 extern int backtrack;
 extern int destructor;
+extern char *initial_action;
 #endif
 
 extern const char *const banner[];
@@ -308,6 +313,7 @@
 extern const char *const body_1[];
 extern const char *const body_vars[];
 extern const char *const body_2[];
+extern const char *const body_3[];
 extern const char *const trailer[];
 
 extern char *code_file_name;
@@ -432,7 +438,12 @@
 extern void at_warning(int a_lineno, int i);
 extern void bad_formals(void) GCC_NORETURN;
 extern void default_action_warning(void);
-extern void destructor_redeclared_warning(int a_lineno, char *a_line, char *a_cptr);
+struct ainfo {
+       int a_lineno;
+       char *a_line;
+       char *a_cptr;
+};
+extern void destructor_redeclared_warning(const struct ainfo *);
 extern void dollar_error(int a_lineno, char *a_line, char *a_cptr) GCC_NORETURN;
 extern void dollar_warning(int a_lineno, int i);
 extern void fatal(const char *msg) GCC_NORETURN;
@@ -459,16 +470,16 @@
 extern void unknown_arg_warning(int d_lineno, const char *dlr_opt, const char *d_arg, const char *d_line, const char *d_cptr);
 extern void unknown_rhs(int i) GCC_NORETURN;
 extern void unsupported_flag_warning(const char *flag, const char *details);
-extern void unterminated_action(int a_lineno, char *a_line, char *a_cptr) GCC_NORETURN;
-extern void unterminated_comment(int c_lineno, char *c_line, char *c_cptr) GCC_NORETURN;
-extern void unterminated_string(int s_lineno, char *s_line, char *s_cptr) GCC_NORETURN;
-extern void unterminated_text(int t_lineno, char *t_line, char *t_cptr) GCC_NORETURN;
-extern void unterminated_union(int u_lineno, char *u_line, char *u_cptr) GCC_NORETURN;
+extern void unterminated_action(const struct ainfo *);
+extern void unterminated_comment(const struct ainfo *) GCC_NORETURN;
+extern void unterminated_string(const struct ainfo *) GCC_NORETURN;
+extern void unterminated_text(const struct ainfo *) GCC_NORETURN;
+extern void unterminated_union(const struct ainfo *) GCC_NORETURN;
 extern void untyped_arg_warning(int a_lineno, const char *dlr_opt, const char *a_name);
 extern void untyped_lhs(void) GCC_NORETURN;
 extern void untyped_rhs(int i, char *s) GCC_NORETURN;
 extern void used_reserved(char *s) GCC_NORETURN;
-extern void unterminated_arglist(int a_lineno, char *a_line, char *a_cptr) GCC_NORETURN;
+extern void unterminated_arglist(const struct ainfo *) GCC_NORETURN;
 extern void wrong_number_args_warning(const char *which, const char *a_name);
 extern void wrong_type_for_arg_warning(int i, char *a_name);
 
diff -r d478b5c9e149 -r a333c69f5241 external/bsd/byacc/dist/error.c
--- a/external/bsd/byacc/dist/error.c   Sun Jan 04 01:26:31 2015 +0000
+++ b/external/bsd/byacc/dist/error.c   Sun Jan 04 01:34:20 2015 +0000
@@ -1,9 +1,9 @@
-/*     $NetBSD: error.c,v 1.9 2015/01/03 23:22:52 christos Exp $       */
+/*     $NetBSD: error.c,v 1.10 2015/01/04 01:34:20 christos Exp $      */
 
 #include "defs.h"
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: error.c,v 1.9 2015/01/03 23:22:52 christos Exp $");
+__RCSID("$NetBSD: error.c,v 1.10 2015/01/04 01:34:20 christos Exp $");
 /* Id: error.c,v 1.11 2014/04/07 22:22:49 tom Exp  */
 
 /* routines for printing error messages  */
@@ -81,38 +81,38 @@
 }
 
 __dead void
-unterminated_comment(int c_lineno, char *c_line, char *c_cptr)
+unterminated_comment(const struct ainfo *a)
 {
     fprintf(stderr, "%s: e - line %d of \"%s\", unmatched /*\n",
-           myname, c_lineno, input_file_name);
-    print_pos(c_line, c_cptr);
+           myname, a->a_lineno, input_file_name);
+    print_pos(a->a_line, a->a_cptr);
     done(1);
 }
 
 __dead void
-unterminated_string(int s_lineno, char *s_line, char *s_cptr)
+unterminated_string(const struct ainfo *a)
 {
     fprintf(stderr, "%s: e - line %d of \"%s\", unterminated string\n",
-           myname, s_lineno, input_file_name);
-    print_pos(s_line, s_cptr);
+           myname, a->a_lineno, input_file_name);
+    print_pos(a->a_line, a->a_cptr);
     done(1);
 }
 
 __dead void
-unterminated_text(int t_lineno, char *t_line, char *t_cptr)
+unterminated_text(const struct ainfo *a)
 {
     fprintf(stderr, "%s: e - line %d of \"%s\", unmatched %%{\n",
-           myname, t_lineno, input_file_name);
-    print_pos(t_line, t_cptr);
+           myname, a->a_lineno, input_file_name);
+    print_pos(a->a_line, a->a_cptr);
     done(1);
 }
 
 __dead void
-unterminated_union(int u_lineno, char *u_line, char *u_cptr)
+unterminated_union(const struct ainfo *a)
 {
     fprintf(stderr, "%s: e - line %d of \"%s\", unterminated %%union \
-declaration\n", myname, u_lineno, input_file_name);
-    print_pos(u_line, u_cptr);
+declaration\n", myname, a->a_lineno, input_file_name);
+    print_pos(a->a_line, a->a_cptr);
     done(1);
 }
 
@@ -222,11 +222,11 @@
 }
 
 void
-unterminated_action(int a_lineno, char *a_line, char *a_cptr)
+unterminated_action(const struct ainfo *a)
 {
     fprintf(stderr, "%s: e - line %d of \"%s\", unterminated action\n",
-           myname, a_lineno, input_file_name);
-    print_pos(a_line, a_cptr);
+           myname, a->a_lineno, input_file_name);
+    print_pos(a->a_line, a->a_cptr);
     done(1);
 }
 
@@ -319,12 +319,12 @@
 }
 
 void
-unterminated_arglist(int a_lineno, char *a_line, char *a_cptr)
+unterminated_arglist(const struct ainfo *a)
 {
     fprintf(stderr,
            "%s: e - line %d of \"%s\", unterminated argument list\n",
-           myname, a_lineno, input_file_name);
-    print_pos(a_line, a_cptr);
+           myname, a->a_lineno, input_file_name);
+    print_pos(a->a_line, a->a_cptr);
     done(1);
 }
 
@@ -397,10 +397,10 @@
 }
 
 void
-destructor_redeclared_warning(int a_lineno, char *a_line, char *a_cptr)
+destructor_redeclared_warning(const struct ainfo *a)
 {
     fprintf(stderr, "%s: w - line %d of \"%s\", destructor redeclared\n",
-           myname, a_lineno, input_file_name);
-    print_pos(a_line, a_cptr);
+           myname, a->a_lineno, input_file_name);
+    print_pos(a->a_line, a->a_cptr);
 }
 #endif
diff -r d478b5c9e149 -r a333c69f5241 external/bsd/byacc/dist/main.c
--- a/external/bsd/byacc/dist/main.c    Sun Jan 04 01:26:31 2015 +0000
+++ b/external/bsd/byacc/dist/main.c    Sun Jan 04 01:34:20 2015 +0000
@@ -1,9 +1,9 @@
-/*     $NetBSD: main.c,v 1.10 2015/01/03 23:22:52 christos Exp $       */
+/*     $NetBSD: main.c,v 1.11 2015/01/04 01:34:20 christos Exp $       */
 
 #include "defs.h"
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: main.c,v 1.10 2015/01/03 23:22:52 christos Exp $");
+__RCSID("$NetBSD: main.c,v 1.11 2015/01/04 01:34:20 christos Exp $");
 /* Id: main.c,v 1.54 2014/10/06 22:40:07 tom Exp  */
 
 #include <signal.h>
@@ -98,6 +98,7 @@
 
 int pure_parser;
 int token_table;
+int error_verbose;
 
 #if defined(YYBTYACC)
 Value_t *symbol_pval;
@@ -105,6 +106,7 @@
 char **symbol_type_tag;
 int locations = 0;     /* default to no position processing */
 int backtrack = 0;     /* default is no backtracking */
+char *initial_action = NULL;
 #endif
 
 int exit_code;
diff -r d478b5c9e149 -r a333c69f5241 external/bsd/byacc/dist/mstring.c
--- a/external/bsd/byacc/dist/mstring.c Sun Jan 04 01:26:31 2015 +0000
+++ b/external/bsd/byacc/dist/mstring.c Sun Jan 04 01:34:20 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mstring.c,v 1.2 2015/01/03 23:22:52 christos Exp $     */
+/*     $NetBSD: mstring.c,v 1.3 2015/01/04 01:34:20 christos Exp $     */
 
 /* Id: mstring.c,v 1.6 2014/04/22 23:36:31 tom Exp  */
 #if HAVE_NBTOOL_CONFIG_H
@@ -6,7 +6,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: mstring.c,v 1.2 2015/01/03 23:22:52 christos Exp $");
+__RCSID("$NetBSD: mstring.c,v 1.3 2015/01/04 01:34:20 christos Exp $");
 
 #include <stdlib.h>
 #include <stdio.h>
@@ -165,20 +165,20 @@
 {
     while (1)
     {
-       while (isspace(*a))
+       while (isspace((unsigned char)*a))
            a++;
-       while (isspace(*b))
+       while (isspace((unsigned char)*b))
            b++;
        while (*a && *a == *b)
            a++, b++;
-       if (isspace(*a))
+       if (isspace((unsigned char)*a))
        {
-           if (isalnum(a[-1]) && isalnum(*b))
+           if (isalnum((unsigned char)a[-1]) && isalnum((unsigned char)*b))
                break;
        }
-       else if (isspace(*b))
+       else if (isspace((unsigned char)*b))
        {
-           if (isalnum(b[-1]) && isalnum(*a))
+           if (isalnum((unsigned char)b[-1]) && isalnum((unsigned char)*a))
                break;
        }
        else
@@ -194,7 +194,7 @@
 
     while (*s)
     {
-       if (!isspace(*s))
+       if (!isspace((unsigned char)*s))
            h = (h << 5) - h + (unsigned char)*s;
        s++;
     }
diff -r d478b5c9e149 -r a333c69f5241 external/bsd/byacc/dist/output.c



Home | Main Index | Thread Index | Old Index