]> git.saurik.com Git - bison.git/blame - src/main.c
* src/output.c (output): Topological sort of the functions, in
[bison.git] / src / main.c
CommitLineData
54bd0db4 1/* Top level entry point of bison,
ceed8467
AD
2 Copyright (C) 1984, 1986, 1989, 1992, 1995, 2000
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"
54bd0db4 29
cc84fd5d 30#if 0 /* XXX currently unused. */
54bd0db4 31/* Nonzero means failure has been detected; don't write a parser file. */
4a120d45
JT
32static int failure;
33#endif
54bd0db4 34
a98ad01e 35/* The name this program was run with, for messages. */
54bd0db4
RS
36char *program_name;
37
cc84fd5d 38extern char *printable_version PARAMS ((int));
cc84fd5d
AD
39
40extern void openfiles PARAMS ((void));
41extern void reader PARAMS ((void));
42extern void reduce_grammar PARAMS ((void));
43extern void set_nullable PARAMS ((void));
44extern void free_nullable PARAMS ((void));
45extern void generate_states PARAMS ((void));
46extern void lalr PARAMS ((void));
47extern void initialize_conflicts PARAMS ((void));
48extern void finalize_conflicts PARAMS ((void));
49extern void verbose PARAMS ((void));
50extern void terse PARAMS ((void));
54bd0db4
RS
51
52
53/* VMS complained about using `int'. */
a98ad01e 54
54bd0db4 55int
d2729d44 56main (int argc, char *argv[])
54bd0db4
RS
57{
58 program_name = argv[0];
29340571
RS
59 setlocale (LC_ALL, "");
60 bindtextdomain (PACKAGE, LOCALEDIR);
61 textdomain (PACKAGE);
62
54bd0db4 63 lineno = 0;
cc84fd5d 64 getargs (argc, argv);
a0f6b076 65
cc84fd5d 66 /* Be ready to clean up if we exit. */
a0f6b076
AD
67 atexit (done);
68
cc84fd5d 69 openfiles ();
54bd0db4 70
cc84fd5d
AD
71 /* Read the input. Copy some parts of it to FGUARD, FACTION, FTABLE
72 and FATTRS. In file reader.c. The other parts are recorded in
73 the grammar; see gram.h. */
a0f6b076
AD
74 reader ();
75 if (complain_message_count)
76 exit (1);
54bd0db4
RS
77
78 /* find useless nonterminals and productions and reduce the grammar. In
79 file reduce.c */
cc84fd5d 80 reduce_grammar ();
54bd0db4
RS
81
82 /* record other info about the grammar. In files derives and nullable. */
cc84fd5d
AD
83 set_derives ();
84 set_nullable ();
54bd0db4
RS
85
86 /* convert to nondeterministic finite state machine. In file LR0.
87 See state.h for more info. */
cc84fd5d 88 generate_states ();
54bd0db4
RS
89
90 /* make it deterministic. In file lalr. */
cc84fd5d 91 lalr ();
54bd0db4 92
cc84fd5d
AD
93 /* Find and record any conflicts: places where one token of
94 lookahead is not enough to disambiguate the parsing. In file
95 conflicts. Also resolve s/r conflicts based on precedence
96 declarations. */
97 initialize_conflicts ();
54bd0db4 98
cc84fd5d
AD
99 /* Print information about results, if requested. In file print.
100 */
54bd0db4 101 if (verboseflag)
cc84fd5d 102 verbose ();
54bd0db4 103 else
cc84fd5d 104 terse ();
54bd0db4 105
cc84fd5d
AD
106 /* Output the tables and the parser to ftable. In file output. */
107 output ();
a0f6b076 108
cc84fd5d
AD
109 finalize_conflicts ();
110 free_nullable ();
111 free_derives ();
4a120d45 112
a0f6b076 113 exit (complain_message_count ? 1 : 0);
54bd0db4 114}
a98ad01e 115\f
a98ad01e
RS
116/* Return a string containing a printable version of C:
117 either C itself, or the corresponding \DDD code. */
118
119char *
d2729d44 120printable_version (int c)
a98ad01e
RS
121{
122 static char buf[10];
123 if (c < ' ' || c >= '\177')
cc84fd5d 124 sprintf (buf, "\\%o", c);
a98ad01e
RS
125 else
126 {
127 buf[0] = c;
128 buf[1] = '\0';
129 }
130 return buf;
131}
132
a98ad01e 133/* Abort for an internal error denoted by string S. */
54bd0db4
RS
134
135void
4a120d45 136berror (const char *s)
54bd0db4 137{
a0f6b076 138 fprintf (stderr, _("%s: internal error: %s\n"), program_name, s);
cc84fd5d 139 abort ();
54bd0db4 140}