123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- /* Top level entry point of bison,
- Copyright (C) 1984, 1986, 1989, 1992 Free Software Foundation, Inc.
- Modified (1992) from bison-1.19 by
- Wilfred J. Hansen (wjh+@cmu.edu)
- Andrew Consortium, Carnegie Mellon University
- This file is part of Bison, the GNU Compiler Compiler.
- Bison is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2, or (at your option)
- any later version.
- Bison is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with Bison; see the file COPYING. If not, write to
- the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
- #include <stdio.h>
- #include "system.h"
- #include "machine.h" /* JF for MAXSHORT */
- extern int lineno;
- extern int verboseflag;
- /* Nonzero means failure has been detected; don't write a parser file. */
- int failure;
- /* The name this program was run with, for messages. */
- char *program_name;
- extern void getargs(), openfiles(), reader(), reduce_grammar();
- extern void set_derives(), set_nullable(), generate_states();
- extern void lalr(), initialize_conflicts(), verbose(), terse();
- extern void output(), done();
- /* VMS complained about using `int'. */
- int
- main(argc, argv)
- int argc;
- char *argv[];
- {
- program_name = argv[0];
- failure = 0;
- lineno = 0;
- getargs(argc, argv);
- openfiles();
- /* read the input. Copy some parts of it to fguard, faction, ftable and fattrs.
- In file reader.c.
- The other parts are recorded in the grammar; see gram.h. */
- reader();
- if (failure)
- done(failure);
- /* find useless nonterminals and productions and reduce the grammar. In
- file reduce.c */
- reduce_grammar();
- /* record other info about the grammar. In files derives and nullable. */
- set_derives();
- set_nullable();
- /* convert to nondeterministic finite state machine. In file LR0.
- See state.h for more info. */
- generate_states();
- /* make it deterministic. In file lalr. */
- lalr();
- /* Find and record any conflicts: places where one token of lookahead is not
- enough to disambiguate the parsing. In file conflicts.
- Currently this does not do anything to resolve them;
- the trivial form of conflict resolution that exists is done in output. */
- initialize_conflicts();
- /* print information about results, if requested. In file print. */
- if (verboseflag)
- verbose();
- else
- terse();
- /* output the tables and the parser to ftable. In file output. */
- output();
- done(failure);
- }
- /* functions to report errors which prevent a parser from being generated */
- /* generate a string from an integer. return internal memory containing string */
- char *
- intToString(i)
- int i;
- {
- static char buf[20];
- sprintf(buf, "%d", i);
- return buf;
- }
- void
- fatal(s)
- char *s;
- {
- extern char *infile;
- if (infile == 0)
- fprintf(stderr, "fatal error: %s\n", s);
- else
- fprintf(stderr, "\"%s\", line %d: %s\n", infile, lineno, s);
- done(1);
- }
- void
- fatals(fmt, x1)
- char *fmt, *x1;
- {
- char buffer[200];
- sprintf(buffer, fmt, x1);
- fatal(buffer);
- }
- void
- warn(s)
- char *s;
- {
- extern char *infile;
- if (infile == 0)
- fprintf(stderr, "error: %s\n", s);
- else
- fprintf(stderr, "(\"%s\", line %d) error: %s\n", infile, lineno, s);
- }
- void
- warni(fmt, x1)
- char *fmt;
- int x1;
- {
- char buffer[200];
- sprintf(buffer, fmt, x1);
- warn(buffer);
- }
- void
- warns(fmt, x1)
- char *fmt, *x1;
- {
- char buffer[200];
- sprintf(buffer, fmt, x1);
- warn(buffer);
- }
- void
- warnss(fmt, x1, x2)
- char *fmt, *x1, *x2;
- {
- char buffer[200];
- sprintf(buffer, fmt, x1, x2);
- warn(buffer);
- }
- void
- warnsss(fmt, x1, x2, x3)
- char *fmt, *x1, *x2, *x3;
- {
- char buffer[200];
- sprintf(buffer, fmt, x1, x2, x3);
- warn(buffer);
- }
- void
- toomany(s)
- char *s;
- {
- char buffer[200];
- /* JF new msg */
- sprintf(buffer, "limit of %d exceeded, too many %s", MAXSHORT, s);
- fatal(buffer);
- }
- void
- berror(s)
- char *s;
- {
- fprintf(stderr, "internal error, %s\n", s);
- abort();
- }
|