]> git.saurik.com Git - bison.git/blobdiff - src/output.c
* src/output.c (output_headers, output_program, output): Be sure
[bison.git] / src / output.c
index b23ffe8ea3160935c978264eff916b86bd3dfa49..27fcae4f2aadaa68ec07c441263f972aac876b14 100644 (file)
@@ -1,5 +1,5 @@
 /* Output the generated parsing program for bison,
 /* Output the generated parsing program for bison,
-   Copyright (C) 1984, 1986, 1989, 1992, 2000 Free Software Foundation, Inc.
+   Copyright 1984, 1986, 1989, 1992, 2000 Free Software Foundation, Inc.
 
    This file is part of Bison, the GNU Compiler Compiler.
 
 
    This file is part of Bison, the GNU Compiler Compiler.
 
@@ -91,6 +91,8 @@
 */
 
 #include "system.h"
 */
 
 #include "system.h"
+#include "obstack.h"
+#include "quotearg.h"
 #include "getargs.h"
 #include "xalloc.h"
 #include "files.h"
 #include "getargs.h"
 #include "xalloc.h"
 #include "files.h"
@@ -125,7 +127,7 @@ static int high;
 
 
 static inline void
 
 
 static inline void
-output_short_or_char_table (FILE *out,
+output_short_or_char_table (struct obstack *oout,
                            const char *comment,
                            const char *type,
                            const char *table_name,
                            const char *comment,
                            const char *type,
                            const char *table_name,
@@ -136,19 +138,19 @@ output_short_or_char_table (FILE *out,
   int i, j;
 
   if (comment)
   int i, j;
 
   if (comment)
-    fprintf (out, "/* %s. */\n", comment);
+    obstack_fgrow1 (oout, "/* %s. */\n", comment);
 
 
-  fprintf (out, "static const %s %s[] =\n{\n  %6d",
-          type, table_name, first_value);
+  obstack_fgrow3 (oout, "static const %s %s[] =\n{\n  %6d",
+                 type, table_name, first_value);
 
   j = 1;
   for (i = begin; i < end; i++)
     {
 
   j = 1;
   for (i = begin; i < end; i++)
     {
-      putc (',', out);
+      obstack_1grow (oout, ',');
 
       if (j >= 10)
        {
 
       if (j >= 10)
        {
-         fputs ("\n  ", out);
+         obstack_grow_literal_string (oout, "\n  ");
          j = 1;
        }
       else
          j = 1;
        }
       else
@@ -156,22 +158,22 @@ output_short_or_char_table (FILE *out,
          j++;
        }
 
          j++;
        }
 
-      fprintf (out, "%6d", short_table[i]);
+      obstack_fgrow1 (oout, "%6d", short_table[i]);
     }
 
     }
 
-  fprintf (out, "\n};\n");
+  obstack_grow_literal_string (oout, "\n};\n");
 }
 
 
 static inline void
 }
 
 
 static inline void
-output_short_table (FILE *out,
+output_short_table (struct obstack *oout,
                    const char *comment,
                    const char *table_name,
                    short *short_table,
                    short first_value,
                    short begin, short end)
 {
                    const char *comment,
                    const char *table_name,
                    short *short_table,
                    short first_value,
                    short begin, short end)
 {
-  output_short_or_char_table (out, comment, "short", table_name, short_table,
+  output_short_or_char_table (oout, comment, "short", table_name, short_table,
                              first_value, begin, end);
 }
 
                              first_value, begin, end);
 }
 
@@ -181,9 +183,11 @@ output_short_table (FILE *out,
 | certain files.                                                |
 `--------------------------------------------------------------*/
 
 | certain files.                                                |
 `--------------------------------------------------------------*/
 
+/* Don't put the `%s' insides quotes, since it quotearg puts them. */
+
 #define        GUARDSTR        \
 "\n\
 #define        GUARDSTR        \
 "\n\
-#include \"%s\"\n\
+#include %s\n\
 extern int yyerror;\n\
 extern int yycost;\n\
 extern char * yymsg;\n\
 extern int yyerror;\n\
 extern int yycost;\n\
 extern char * yymsg;\n\
@@ -202,7 +206,7 @@ register YYLTYPE *yylsp;\n\
 
 #define        ACTSTR          \
 "\n\
 
 #define        ACTSTR          \
 "\n\
-#include \"%s\"\n\
+#include %s\n\
 extern YYSTYPE yyval;\n\
 extern int yychar;\n\
 \n\
 extern YYSTYPE yyval;\n\
 extern int yychar;\n\
 \n\
@@ -219,13 +223,19 @@ register YYLTYPE *yylsp;\n\
 void
 output_headers (void)
 {
 void
 output_headers (void)
 {
+  char *attrsfile_quoted = quotearg_style (c_quoting_style, attrsfile);
+
   if (semantic_parser)
   if (semantic_parser)
-    fprintf (fguard, GUARDSTR, attrsfile);
+    fprintf (fguard, GUARDSTR, attrsfile_quoted);
 
   if (no_parser_flag)
     return;
 
 
   if (no_parser_flag)
     return;
 
-  fprintf (faction, (semantic_parser ? ACTSTR : ACTSTR_SIMPLE), attrsfile);
+  if (semantic_parser)
+    obstack_fgrow1 (&action_obstack, ACTSTR, attrsfile_quoted);
+  else
+    obstack_grow_literal_string (&action_obstack, ACTSTR_SIMPLE);
+
 /*  if (semantic_parser)       JF moved this below
     fprintf(ftable, "#include \"%s\"\n", attrsfile);
   fprintf(ftable, "#include <stdio.h>\n\n");
 /*  if (semantic_parser)       JF moved this below
     fprintf(ftable, "#include \"%s\"\n", attrsfile);
   fprintf(ftable, "#include <stdio.h>\n\n");
@@ -234,13 +244,20 @@ output_headers (void)
   /* Rename certain symbols if -p was specified.  */
   if (spec_name_prefix)
     {
   /* Rename certain symbols if -p was specified.  */
   if (spec_name_prefix)
     {
-      fprintf (ftable, "#define yyparse %sparse\n", spec_name_prefix);
-      fprintf (ftable, "#define yylex %slex\n", spec_name_prefix);
-      fprintf (ftable, "#define yyerror %serror\n", spec_name_prefix);
-      fprintf (ftable, "#define yylval %slval\n", spec_name_prefix);
-      fprintf (ftable, "#define yychar %schar\n", spec_name_prefix);
-      fprintf (ftable, "#define yydebug %sdebug\n", spec_name_prefix);
-      fprintf (ftable, "#define yynerrs %snerrs\n", spec_name_prefix);
+      obstack_fgrow1 (&table_obstack,
+                     "#define yyparse %sparse\n", spec_name_prefix);
+      obstack_fgrow1 (&table_obstack,
+                     "#define yylex %slex\n", spec_name_prefix);
+      obstack_fgrow1 (&table_obstack,
+                     "#define yyerror %serror\n", spec_name_prefix);
+      obstack_fgrow1 (&table_obstack,
+                     "#define yylval %slval\n", spec_name_prefix);
+      obstack_fgrow1 (&table_obstack,
+                     "#define yychar %schar\n", spec_name_prefix);
+      obstack_fgrow1 (&table_obstack,
+                     "#define yydebug %sdebug\n", spec_name_prefix);
+      obstack_fgrow1 (&table_obstack,
+                     "#define yynerrs %snerrs\n", spec_name_prefix);
     }
 }
 
     }
 }
 
@@ -255,14 +272,15 @@ output_trailers (void)
   if (semantic_parser)
     fprintf (fguard, "\n    }\n}\n");
 
   if (semantic_parser)
     fprintf (fguard, "\n    }\n}\n");
 
-  fprintf (faction, "\n");
+  obstack_1grow (&action_obstack, '\n');
 
   if (no_parser_flag)
     return;
 
   if (semantic_parser)
 
   if (no_parser_flag)
     return;
 
   if (semantic_parser)
-    fprintf (faction, "    }\n");
-  fprintf (faction, "}\n");
+    obstack_grow_literal_string (&action_obstack, "    }\n");
+
+  obstack_grow_literal_string (&action_obstack, "}\n");
 }
 
 
 }
 
 
@@ -270,19 +288,19 @@ output_trailers (void)
 static void
 output_token_translations (void)
 {
 static void
 output_token_translations (void)
 {
-  fputs ("\
+  obstack_grow_literal_string (&table_obstack, "\
 \n\
 \n\
-/* YYRANSLATE(YYLEX) -- Bison token number corresponding to YYLEX. */\n",
-        ftable);
+/* YYRANSLATE(YYLEX) -- Bison token number corresponding to YYLEX. */\n");
+
   if (translations)
     {
   if (translations)
     {
-      fprintf (ftable,
+      obstack_fgrow2 (&table_obstack,
       "#define YYTRANSLATE(x) ((unsigned)(x) <= %d ? yytranslate[x] : %d)\
 \n\
 \n",
               max_user_token_number, nsyms);
 
       "#define YYTRANSLATE(x) ((unsigned)(x) <= %d ? yytranslate[x] : %d)\
 \n\
 \n",
               max_user_token_number, nsyms);
 
-      output_short_or_char_table (ftable,
+      output_short_or_char_table (&table_obstack,
             "YYRANSLATE[YYLEX] -- Bison token number corresponding to YYLEX",
                    ntokens < 127 ? "char" : "short",
                    "yytranslate", token_translations,
             "YYRANSLATE[YYLEX] -- Bison token number corresponding to YYLEX",
                    ntokens < 127 ? "char" : "short",
                    "yytranslate", token_translations,
@@ -290,7 +308,8 @@ output_token_translations (void)
     }
   else
     {
     }
   else
     {
-      fprintf (ftable, "\n#define YYTRANSLATE(x) (x)\n");
+      obstack_grow_literal_string (&table_obstack,
+                                  "\n#define YYTRANSLATE(x) (x)\n");
     }
 }
 
     }
 }
 
@@ -302,9 +321,9 @@ output_gram (void)
      yyprhs and yyrhs are needed only for yydebug. */
   /* With the no_parser option, all tables are generated */
   if (!semantic_parser && !no_parser_flag)
      yyprhs and yyrhs are needed only for yydebug. */
   /* With the no_parser option, all tables are generated */
   if (!semantic_parser && !no_parser_flag)
-    fprintf (ftable, "\n#if YYDEBUG != 0\n");
+    obstack_grow_literal_string (&table_obstack, "\n#if YYDEBUG != 0\n");
 
 
-  output_short_table (ftable, NULL, "yyprhs", rrhs,
+  output_short_table (&table_obstack, NULL, "yyprhs", rrhs,
                      0, 1, nrules + 1);
 
   {
                      0, 1, nrules + 1);
 
   {
@@ -319,20 +338,20 @@ output_gram (void)
     for (sp = ritem + 1, i = 1; *sp; ++sp, ++i)
       yyrhs[i] = *sp > 0 ? *sp : 0;
 
     for (sp = ritem + 1, i = 1; *sp; ++sp, ++i)
       yyrhs[i] = *sp > 0 ? *sp : 0;
 
-    output_short_table (ftable, NULL, "yyrhs", yyrhs,
+    output_short_table (&table_obstack, NULL, "yyrhs", yyrhs,
                        ritem[0], 1, yyrhs_size);
     XFREE (yyrhs);
   }
 
   if (!semantic_parser && !no_parser_flag)
                        ritem[0], 1, yyrhs_size);
     XFREE (yyrhs);
   }
 
   if (!semantic_parser && !no_parser_flag)
-    fprintf (ftable, "\n#endif\n");
+    obstack_grow_literal_string (&table_obstack, "\n#endif\n");
 }
 
 
 static void
 output_stos (void)
 {
 }
 
 
 static void
 output_stos (void)
 {
-  output_short_table (ftable, NULL, "yystos", accessing_symbol,
+  output_short_table (&table_obstack, NULL, "yystos", accessing_symbol,
                      0, 1, nstates);
 }
 
                      0, 1, nstates);
 }
 
@@ -344,33 +363,33 @@ output_rule_data (void)
   int j;
   short *short_tab = NULL;
 
   int j;
   short *short_tab = NULL;
 
-  fputs ("\n\
-#if YYDEBUG != 0\n",
-        ftable);
+  obstack_grow_literal_string (&table_obstack, "\n\
+#if YYDEBUG != 0\n");
 
 
-  output_short_table (ftable,
+  output_short_table (&table_obstack,
            "YYRLINE[YYN] -- source line where rule number YYN was defined",
                      "yyrline", rline,
                      0, 1, nrules + 1);
 
            "YYRLINE[YYN] -- source line where rule number YYN was defined",
                      "yyrline", rline,
                      0, 1, nrules + 1);
 
-  fputs ("#endif\n\n", ftable);
+  obstack_grow_literal_string (&table_obstack, "#endif\n\n");
 
   if (token_table_flag || no_parser_flag)
     {
 
   if (token_table_flag || no_parser_flag)
     {
-      fprintf (ftable, "#define YYNTOKENS %d\n", ntokens);
-      fprintf (ftable, "#define YYNNTS %d\n", nvars);
-      fprintf (ftable, "#define YYNRULES %d\n", nrules);
-      fprintf (ftable, "#define YYNSTATES %d\n", nstates);
-      fprintf (ftable, "#define YYMAXUTOK %d\n\n", max_user_token_number);
+      obstack_fgrow1 (&table_obstack, "#define YYNTOKENS %d\n", ntokens);
+      obstack_fgrow1 (&table_obstack, "#define YYNNTS %d\n", nvars);
+      obstack_fgrow1 (&table_obstack, "#define YYNRULES %d\n", nrules);
+      obstack_fgrow1 (&table_obstack, "#define YYNSTATES %d\n", nstates);
+      obstack_fgrow1 (&table_obstack, "#define YYMAXUTOK %d\n\n",
+                     max_user_token_number);
     }
 
   /* Output the table of symbol names.  */
   if (!token_table_flag && !no_parser_flag)
     }
 
   /* Output the table of symbol names.  */
   if (!token_table_flag && !no_parser_flag)
-    fputs ("\n#if YYDEBUG != 0 || defined YYERROR_VERBOSE\n\n", ftable);
-  fputs ("\
-/* YYTNAME[TOKEN_NUM] -- String name of the token TOKEN_NUM. */\n",
-        ftable);
-  fprintf (ftable,
+    obstack_grow_literal_string (&table_obstack,
+                         "\n#if YYDEBUG != 0 || defined YYERROR_VERBOSE\n\n");
+  obstack_grow_literal_string (&table_obstack, "\
+/* YYTNAME[TOKEN_NUM] -- String name of the token TOKEN_NUM. */\n");
+  obstack_grow_literal_string (&table_obstack,
           "static const char *const yytname[] =\n{\n  ");
 
   j = 0;
           "static const char *const yytname[] =\n{\n  ");
 
   j = 0;
@@ -394,76 +413,76 @@ output_rule_data (void)
 
       if (j + strsize > 75)
        {
 
       if (j + strsize > 75)
        {
-         fputs ("\n  ", ftable);
+         obstack_grow_literal_string (&table_obstack, "\n  ");
          j = 2;
        }
 
          j = 2;
        }
 
-      putc ('\"', ftable);
+      obstack_1grow (&table_obstack, '\"');
       for (p = tags[i]; p && *p; p++)
        {
          if (*p == '"' || *p == '\\')
            {
       for (p = tags[i]; p && *p; p++)
        {
          if (*p == '"' || *p == '\\')
            {
-             fprintf (ftable, "\\%c", *p);
+             obstack_fgrow1 (&table_obstack, "\\%c", *p);
            }
          else if (*p == '\n')
            {
            }
          else if (*p == '\n')
            {
-             fprintf (ftable, "\\n");
+             obstack_grow_literal_string (&table_obstack, "\\n");
            }
          else if (*p == '\t')
            {
            }
          else if (*p == '\t')
            {
-             fprintf (ftable, "\\t");
+             obstack_grow_literal_string (&table_obstack, "\\t");
            }
          else if (*p == '\b')
            {
            }
          else if (*p == '\b')
            {
-             fprintf (ftable, "\\b");
+             obstack_grow_literal_string (&table_obstack, "\\b");
            }
          else if (*p < 040 || *p >= 0177)
            {
            }
          else if (*p < 040 || *p >= 0177)
            {
-             fprintf (ftable, "\\%03o", *p);
+             obstack_fgrow1 (&table_obstack, "\\%03o", *p);
            }
          else
            {
            }
          else
            {
-             putc (*p, ftable);
+             obstack_1grow (&table_obstack, *p);
            }
        }
 
            }
        }
 
-      fputs ("\", ", ftable);
+      obstack_grow_literal_string (&table_obstack, "\", ");
       j += strsize;
     }
   /* add a NULL entry to list of tokens */
       j += strsize;
     }
   /* add a NULL entry to list of tokens */
-  fprintf (ftable, "NULL\n};\n");
+  obstack_grow_literal_string (&table_obstack, "NULL\n};\n");
 
   if (!token_table_flag && !no_parser_flag)
 
   if (!token_table_flag && !no_parser_flag)
-    fprintf (ftable, "#endif\n\n");
+    obstack_grow_literal_string (&table_obstack, "#endif\n\n");
 
   /* Output YYTOKNUM. */
   if (token_table_flag)
     {
 
   /* Output YYTOKNUM. */
   if (token_table_flag)
     {
-      output_short_table (ftable,
+      output_short_table (&table_obstack,
                  "YYTOKNUM[YYLEX] -- Index in YYTNAME corresponding to YYLEX",
                          "yytoknum", user_toknums,
                          0, 1, ntokens + 1);
     }
 
   /* Output YYR1. */
                  "YYTOKNUM[YYLEX] -- Index in YYTNAME corresponding to YYLEX",
                          "yytoknum", user_toknums,
                          0, 1, ntokens + 1);
     }
 
   /* Output YYR1. */
-  output_short_table (ftable,
+  output_short_table (&table_obstack,
              "YYR1[YYN] -- Symbol number of symbol that rule YYN derives",
                      "yyr1", rlhs,
                      0, 1, nrules + 1);
   XFREE (rlhs + 1);
 
              "YYR1[YYN] -- Symbol number of symbol that rule YYN derives",
                      "yyr1", rlhs,
                      0, 1, nrules + 1);
   XFREE (rlhs + 1);
 
-  putc ('\n', ftable);
+  obstack_1grow (&table_obstack, '\n');
 
   /* Output YYR2. */
   short_tab = XMALLOC (short, nrules + 1);
   for (i = 1; i < nrules; i++)
     short_tab[i] = rrhs[i + 1] - rrhs[i] - 1;
   short_tab[nrules] = nitems - rrhs[nrules] - 1;
 
   /* Output YYR2. */
   short_tab = XMALLOC (short, nrules + 1);
   for (i = 1; i < nrules; i++)
     short_tab[i] = rrhs[i + 1] - rrhs[i] - 1;
   short_tab[nrules] = nitems - rrhs[nrules] - 1;
-  output_short_table (ftable,
+  output_short_table (&table_obstack,
         "YYR2[YYN] -- Number of symbols composing right hand side of rule YYN",
                      "yyr2", short_tab,
                      0, 1, nrules + 1);
         "YYR2[YYN] -- Number of symbols composing right hand side of rule YYN",
                      "yyr2", short_tab,
                      0, 1, nrules + 1);
-  putc ('\n', ftable);
+  obstack_1grow (&table_obstack, '\n');
 
   XFREE (short_tab);
 
 
   XFREE (short_tab);
 
@@ -474,9 +493,9 @@ output_rule_data (void)
 static void
 output_defines (void)
 {
 static void
 output_defines (void)
 {
-  fprintf (ftable, "\n\n#define\tYYFINAL\t\t%d\n", final_state);
-  fprintf (ftable, "#define\tYYFLAG\t\t%d\n", MINSHORT);
-  fprintf (ftable, "#define\tYYNTBASE\t%d\n", ntokens);
+  obstack_fgrow1 (&table_obstack, "\n\n#define\tYYFINAL\t\t%d\n", final_state);
+  obstack_fgrow1 (&table_obstack, "#define\tYYFLAG\t\t%d\n", MINSHORT);
+  obstack_fgrow1 (&table_obstack, "#define\tYYNTBASE\t%d\n", ntokens);
 }
 
 
 }
 
 
@@ -722,13 +741,13 @@ token_actions (void)
     }
   XFREE (actrow);
 
     }
   XFREE (actrow);
 
-  output_short_table (ftable,
+  output_short_table (&table_obstack,
   "YYDEFACT[S] -- default rule to reduce with in state S when YYTABLE\n\
    doesn't specify something else to do.  Zero means the default is an\n\
    error",
                      "yydefact", yydefact,
                      yydefact[0], 1, nstates);
   "YYDEFACT[S] -- default rule to reduce with in state S when YYTABLE\n\
    doesn't specify something else to do.  Zero means the default is an\n\
    error",
                      "yydefact", yydefact,
                      yydefact[0], 1, nstates);
-  putc ('\n', ftable);
+  obstack_1grow (&table_obstack, '\n');
   XFREE (yydefact);
 }
 
   XFREE (yydefact);
 }
 
@@ -866,7 +885,7 @@ goto_actions (void)
       yydefgoto[i - ntokens] = default_state;
     }
 
       yydefgoto[i - ntokens] = default_state;
     }
 
-  output_short_table (ftable, NULL, "yydefgoto", yydefgoto,
+  output_short_table (&table_obstack, NULL, "yydefgoto", yydefgoto,
                      yydefgoto[0], 1, nsyms - ntokens);
 
   XFREE (state_count);
                      yydefgoto[0], 1, nsyms - ntokens);
 
   XFREE (state_count);
@@ -1069,12 +1088,12 @@ pack_table (void)
 static void
 output_base (void)
 {
 static void
 output_base (void)
 {
-  output_short_table (ftable, NULL, "yypact", base,
+  output_short_table (&table_obstack, NULL, "yypact", base,
                      base[0], 1, nstates);
 
                      base[0], 1, nstates);
 
-  putc ('\n', ftable);
+  obstack_1grow (&table_obstack, '\n');
 
 
-  output_short_table (ftable, NULL, "yypgoto", base,
+  output_short_table (&table_obstack, NULL, "yypgoto", base,
                      base[nstates], nstates + 1, nvectors);
 
   XFREE (base);
                      base[nstates], nstates + 1, nvectors);
 
   XFREE (base);
@@ -1084,8 +1103,8 @@ output_base (void)
 static void
 output_table (void)
 {
 static void
 output_table (void)
 {
-  fprintf (ftable, "\n\n#define\tYYLAST\t\t%d\n\n\n", high);
-  output_short_table (ftable, NULL, "yytable", table,
+  obstack_fgrow1 (&table_obstack, "\n\n#define\tYYLAST\t\t%d\n\n\n", high);
+  output_short_table (&table_obstack, NULL, "yytable", table,
                      table[0], 1, high + 1);
   XFREE (table);
 }
                      table[0], 1, high + 1);
   XFREE (table);
 }
@@ -1094,7 +1113,7 @@ output_table (void)
 static void
 output_check (void)
 {
 static void
 output_check (void)
 {
-  output_short_table (ftable, NULL, "yycheck", check,
+  output_short_table (&table_obstack, NULL, "yycheck", check,
                      check[0], 1, high + 1);
   XFREE (check);
 }
                      check[0], 1, high + 1);
   XFREE (check);
 }
@@ -1127,10 +1146,10 @@ output_actions (void)
 
   sort_actions ();
   pack_table ();
 
   sort_actions ();
   pack_table ();
-  putc ('\n', ftable);
+  obstack_1grow (&table_obstack, '\n');
   output_base ();
   output_table ();
   output_base ();
   output_table ();
-  putc ('\n', ftable);
+  obstack_1grow (&table_obstack, '\n');
   output_check ();
 }
 
   output_check ();
 }
 
@@ -1148,7 +1167,7 @@ output_parser (void)
 #endif
 
   if (pure_parser)
 #endif
 
   if (pure_parser)
-    fprintf (ftable, "#define YYPURE 1\n\n");
+    obstack_grow_literal_string (&table_obstack, "#define YYPURE 1\n\n");
 
 #ifdef DONTDEF
   /* JF no longer needed 'cuz open_extra_files changes the currently
 
 #ifdef DONTDEF
   /* JF no longer needed 'cuz open_extra_files changes the currently
@@ -1185,40 +1204,43 @@ output_parser (void)
                        if (c == 'e')
                          write_line = 0;
                        else
                        if (c == 'e')
                          write_line = 0;
                        else
-                         fprintf (ftable, "#lin");
+                         obstack_grow_literal_string (&table_obstack, "#lin");
                      }
                    else
                      }
                    else
-                     fprintf (ftable, "#li");
+                     obstack_grow_literal_string (&table_obstack, "#li");
                  }
                else
                  }
                else
-                 fprintf (ftable, "#l");
+                 obstack_grow_literal_string (&table_obstack, "#l");
              }
            else
              }
            else
-             fprintf (ftable, "#");
+             obstack_grow_literal_string (&table_obstack, "#");
          }
 
       /* now write out the line... */
       for (; c != '\n' && c != EOF; c = getc (fpars))
        if (write_line)
          {
          }
 
       /* now write out the line... */
       for (; c != '\n' && c != EOF; c = getc (fpars))
        if (write_line)
          {
+           /* `$' in the parser file indicates where to put the
+              actions.  Copy them in at this point.  */
            if (c == '$')
              {
            if (c == '$')
              {
+               size_t size = obstack_object_size (&action_obstack);
+
                number_of_dollar_signs++;
                assert (number_of_dollar_signs == 1);
                number_of_dollar_signs++;
                assert (number_of_dollar_signs == 1);
-               /* `$' in the parser file indicates where to put the actions.
-                  Copy them in at this point.  */
-               rewind (faction);
-               for (c = getc (faction); c != EOF; c = getc (faction))
-                 putc (c, ftable);
+               obstack_grow (&table_obstack,
+                             obstack_finish (&action_obstack),
+                             size);
+
                /* Skip the end of the line containing `$'. */
                write_line = 0;
              }
            else
                /* Skip the end of the line containing `$'. */
                write_line = 0;
              }
            else
-             putc (c, ftable);
+             obstack_1grow (&table_obstack, c);
          }
       if (c == EOF)
        break;
          }
       if (c == EOF)
        break;
-      putc (c, ftable);
+      obstack_1grow (&table_obstack, c);
     }
   assert (number_of_dollar_signs == 1);
 }
     }
   assert (number_of_dollar_signs == 1);
 }
@@ -1229,14 +1251,11 @@ output_program (void)
   int c;
 
   if (!no_lines_flag)
   int c;
 
   if (!no_lines_flag)
-    fprintf (ftable, "#line %d \"%s\"\n", lineno, infile);
+    obstack_fgrow2 (&table_obstack, "#line %d %s\n",
+                   lineno, quotearg_style (c_quoting_style, infile));
 
 
-  c = getc (finput);
-  while (c != EOF)
-    {
-      putc (c, ftable);
-      c = getc (finput);
-    }
+  while ((c = getc (finput)) != EOF)
+    obstack_1grow (&table_obstack, c);
 }
 
 
 }
 
 
@@ -1262,39 +1281,38 @@ free_itemsets (void)
 void
 output (void)
 {
 void
 output (void)
 {
-  int c;
-
   /* output_token_defines(ftable);      / * JF put out token defines FIRST */
   /* output_token_defines(ftable);      / * JF put out token defines FIRST */
-  if (!semantic_parser)                /* JF Put out other stuff */
+
+  /* If using a simple parser the definition of YYSTYPE are put into
+     TABLE_OBSTACK.  */
+  if (!semantic_parser)
     {
     {
-      rewind (fattrs);
-      while ((c = getc (fattrs)) != EOF)
-       putc (c, ftable);
+      size_t size = obstack_object_size (&attrs_obstack);
+      obstack_grow (&table_obstack, obstack_finish (&attrs_obstack), size);
     }
     }
-  reader_output_yylsp (ftable);
+  reader_output_yylsp (&table_obstack);
   if (debug_flag)
   if (debug_flag)
-    fputs ("\
+    obstack_grow_literal_string (&table_obstack, "\
 #ifndef YYDEBUG\n\
 # define YYDEBUG 1\n\
 #endif\n\
 #ifndef YYDEBUG\n\
 # define YYDEBUG 1\n\
 #endif\n\
-\n",
-          ftable);
+\n");
 
   if (semantic_parser)
 
   if (semantic_parser)
-    fprintf (ftable, "#include \"%s\"\n", attrsfile);
+    obstack_fgrow1 (&table_obstack, "#include %s\n",
+                   quotearg_style (c_quoting_style, attrsfile));
 
   if (!no_parser_flag)
 
   if (!no_parser_flag)
-    fprintf (ftable, "#include <stdio.h>\n\n");
+    obstack_grow_literal_string (&table_obstack, "#include <stdio.h>\n\n");
 
   /* Make "const" do nothing if not in ANSI C.  */
 
   /* Make "const" do nothing if not in ANSI C.  */
-  fputs ("\
+  obstack_grow_literal_string (&table_obstack, "\
 #ifndef __cplusplus\n\
 # ifndef __STDC__\n\
 #  define const\n\
 # endif\n\
 #endif\n\
 #ifndef __cplusplus\n\
 # ifndef __STDC__\n\
 #  define const\n\
 # endif\n\
 #endif\n\
-\n",
-        ftable);
+\n");
 
   free_itemsets ();
   output_defines ();
 
   free_itemsets ();
   output_defines ();