]> git.saurik.com Git - bison.git/blame - src/main.c
* src/LR0.c (new_state, get_state): Complete TRACE code.
[bison.git] / src / main.c
CommitLineData
54bd0db4 1/* Top level entry point of bison,
342b8b6e 2 Copyright 1984, 1986, 1989, 1992, 1995, 2000, 2001
ceed8467 3 Free Software Foundation, Inc.
54bd0db4 4
e87b5700 5 This file is part of Bison, the GNU Compiler Compiler.
54bd0db4 6
e87b5700
AD
7 Bison is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
54bd0db4 11
e87b5700
AD
12 Bison is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
54bd0db4 16
e87b5700
AD
17 You should have received a copy of the GNU General Public License
18 along with Bison; see the file COPYING. If not, write to
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA. */
54bd0db4
RS
21
22
54bd0db4 23#include "system.h"
ceed8467 24#include "getargs.h"
a0f6b076
AD
25#include "files.h"
26#include "complain.h"
cc84fd5d 27#include "derives.h"
6c89f1c1 28#include "output.h"
a70083a3
AD
29#include "reader.h"
30#include "lalr.h"
015acc48 31#include "reduce.h"
3519ec76 32#include "nullable.h"
07a58c13 33#include "print.h"
403b315b 34#include "LR0.h"
d7913476 35#include "conflicts.h"
c4b66126 36#include "print_graph.h"
11d82f03 37#include "muscle_tab.h"
342b8b6e
AD
38#include "symtab.h"
39#include "lex.h"
54bd0db4 40
a98ad01e 41/* The name this program was run with, for messages. */
54bd0db4
RS
42char *program_name;
43
d019d655
AD
44extern void berror PARAMS((const char *));
45
54bd0db4 46int
d2729d44 47main (int argc, char *argv[])
54bd0db4
RS
48{
49 program_name = argv[0];
29340571
RS
50 setlocale (LC_ALL, "");
51 bindtextdomain (PACKAGE, LOCALEDIR);
52 textdomain (PACKAGE);
53
54bd0db4 54 lineno = 0;
cc84fd5d 55 getargs (argc, argv);
a0f6b076 56
11d82f03 57 muscle_init ();
8963a27b 58 open_files ();
54bd0db4 59
cc84fd5d
AD
60 /* Read the input. Copy some parts of it to FGUARD, FACTION, FTABLE
61 and FATTRS. In file reader.c. The other parts are recorded in
62 the grammar; see gram.h. */
a0f6b076
AD
63 reader ();
64 if (complain_message_count)
65 exit (1);
54bd0db4 66
7da99ede
AD
67 /* Find useless nonterminals and productions and reduce the grammar.
68 In file reduce.c. */
cc84fd5d 69 reduce_grammar ();
54bd0db4 70
7da99ede
AD
71 /* Record other info about the grammar. In files derives and
72 nullable. */
cc84fd5d
AD
73 set_derives ();
74 set_nullable ();
54bd0db4 75
7da99ede 76 /* Convert to nondeterministic finite state machine. In file LR0.
54bd0db4 77 See state.h for more info. */
cc84fd5d 78 generate_states ();
54bd0db4
RS
79
80 /* make it deterministic. In file lalr. */
cc84fd5d 81 lalr ();
54bd0db4 82
cc84fd5d
AD
83 /* Find and record any conflicts: places where one token of
84 lookahead is not enough to disambiguate the parsing. In file
85 conflicts. Also resolve s/r conflicts based on precedence
86 declarations. */
342b8b6e 87 solve_conflicts ();
0df87bb6 88 conflicts_print ();
342b8b6e
AD
89
90 /* Output file names. */
91 compute_output_file_names ();
92
93 /* Stop if there were errors, to avoid trashing previous output
94 files. */
95 if (complain_message_count)
96 exit (1);
54bd0db4 97
0df87bb6 98 /* Output the detailed report on the grammar. */
07a58c13 99 print_results ();
54bd0db4 100
e8cb70b9 101 /* Output the VCG graph. */
c4b66126
AD
102 print_graph ();
103
cc84fd5d
AD
104 /* Output the tables and the parser to ftable. In file output. */
105 output ();
a0f6b076 106
7da99ede
AD
107 /* Close the input files. */
108 close_files ();
109
342b8b6e
AD
110 /* Free the symbol table data structure. */
111 free_symtab ();
112
113 lex_free ();
114
337c5bd1 115 reduce_free ();
342b8b6e 116 free_conflicts ();
cc84fd5d
AD
117 free_nullable ();
118 free_derives ();
4a120d45 119
342b8b6e 120 output_files ();
d8880f69 121
0f37a994 122 return complain_message_count ? EXIT_FAILURE : EXIT_SUCCESS;
54bd0db4 123}
a98ad01e 124\f
a98ad01e 125/* Abort for an internal error denoted by string S. */
54bd0db4
RS
126
127void
4a120d45 128berror (const char *s)
54bd0db4 129{
a0f6b076 130 fprintf (stderr, _("%s: internal error: %s\n"), program_name, s);
cc84fd5d 131 abort ();
54bd0db4 132}