* pt.c (instantiate_decl): Tell the repository code about the
[official-gcc.git] / gcc / toplev.h
blobe621857826fe8099261ff9cf20798bffa30164a3
1 /* toplev.h - Various declarations for functions found in toplev.c
2 Copyright (C) 1998, 1999, 2000, 2001 Free Software Foundation, Inc.
4 This file is part of GNU CC.
6 GNU CC is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
9 any later version.
11 GNU CC is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNU CC; see the file COPYING. If not, write to
18 the Free Software Foundation, 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA. */
21 #ifndef __GCC_TOPLEV_H__
22 #define __GCC_TOPLEV_H__
24 #ifdef ANSI_PROTOTYPES
25 union tree_node;
26 struct rtx_def;
27 #endif
29 /* If non-NULL, return one past-the-end of the matching SUBPART of
30 the WHOLE string. */
31 #define skip_leading_substring(whole, part) \
32 (strncmp (whole, part, strlen (part)) ? NULL : whole + strlen (part))
34 extern int read_integral_parameter PARAMS ((const char *, const char *,
35 const int));
36 extern int count_error PARAMS ((int));
37 extern void strip_off_ending PARAMS ((char *, int));
38 extern char *file_name_nondirectory PARAMS ((const char *));
39 extern void print_time PARAMS ((const char *, long));
40 extern void debug_start_source_file PARAMS ((const char *));
41 extern void debug_end_source_file PARAMS ((unsigned));
42 extern void debug_define PARAMS ((unsigned, const char *));
43 extern void debug_undef PARAMS ((unsigned, const char *));
44 extern int debug_ignore_block PARAMS ((union tree_node *));
45 extern const char *trim_filename PARAMS ((const char *));
46 extern void internal_error PARAMS ((const char *, ...))
47 ATTRIBUTE_PRINTF_1
48 ATTRIBUTE_NORETURN;
49 extern void fatal_io_error PARAMS ((const char *, ...))
50 ATTRIBUTE_PRINTF_1
51 ATTRIBUTE_NORETURN;
52 extern void _fatal_insn_not_found PARAMS ((struct rtx_def *,
53 const char *, int,
54 const char *))
55 ATTRIBUTE_NORETURN;
56 extern void _fatal_insn PARAMS ((const char *,
57 struct rtx_def *,
58 const char *, int,
59 const char *))
60 ATTRIBUTE_NORETURN;
62 #define fatal_insn(msgid, insn) \
63 _fatal_insn (msgid, insn, __FILE__, __LINE__, __FUNCTION__)
64 #define fatal_insn_not_found(insn) \
65 _fatal_insn_not_found (insn, __FILE__, __LINE__, __FUNCTION__)
67 extern void warning PARAMS ((const char *, ...))
68 ATTRIBUTE_PRINTF_1;
69 extern void error PARAMS ((const char *, ...))
70 ATTRIBUTE_PRINTF_1;
71 extern void fatal_error PARAMS ((const char *, ...))
72 ATTRIBUTE_PRINTF_1;
73 extern void pedwarn PARAMS ((const char *, ...))
74 ATTRIBUTE_PRINTF_1;
75 extern void pedwarn_with_file_and_line PARAMS ((const char *, int,
76 const char *, ...))
77 ATTRIBUTE_PRINTF_3;
78 extern void warning_with_file_and_line PARAMS ((const char *, int,
79 const char *, ...))
80 ATTRIBUTE_PRINTF_3;
81 extern void error_with_file_and_line PARAMS ((const char *, int,
82 const char *, ...))
83 ATTRIBUTE_PRINTF_3;
84 extern void sorry PARAMS ((const char *, ...))
85 ATTRIBUTE_PRINTF_1;
86 extern void default_print_error_function PARAMS ((const char *));
87 extern void report_error_function PARAMS ((const char *));
89 extern void rest_of_decl_compilation PARAMS ((union tree_node *,
90 const char *, int, int));
91 extern void rest_of_type_compilation PARAMS ((union tree_node *, int));
92 extern void rest_of_compilation PARAMS ((union tree_node *));
94 /* The *_with_decl functions aren't suitable for ATTRIBUTE_PRINTF. */
95 extern void pedwarn_with_decl PARAMS ((union tree_node *,
96 const char *, ...));
97 extern void warning_with_decl PARAMS ((union tree_node *,
98 const char *, ...));
99 extern void error_with_decl PARAMS ((union tree_node *,
100 const char *, ...));
102 extern void announce_function PARAMS ((union tree_node *));
104 extern void error_for_asm PARAMS ((struct rtx_def *,
105 const char *, ...))
106 ATTRIBUTE_PRINTF_2;
107 extern void warning_for_asm PARAMS ((struct rtx_def *,
108 const char *, ...))
109 ATTRIBUTE_PRINTF_2;
110 #if defined (_JBLEN) || defined (setjmp)
111 extern void set_float_handler PARAMS ((jmp_buf));
112 extern int push_float_handler PARAMS ((jmp_buf, jmp_buf));
113 extern void pop_float_handler PARAMS ((int, jmp_buf));
114 #endif
115 extern int do_float_handler PARAMS ((void (*) (PTR), PTR));
117 #ifdef BUFSIZ
118 extern void output_quoted_string PARAMS ((FILE *, const char *));
119 extern void output_file_directive PARAMS ((FILE *, const char *));
120 #endif
121 extern void do_abort PARAMS ((void)) ATTRIBUTE_NORETURN;
122 extern void botch PARAMS ((const char *))
123 ATTRIBUTE_NORETURN;
125 #ifdef BUFSIZ
126 extern void fnotice PARAMS ((FILE *, const char *, ...))
127 ATTRIBUTE_PRINTF_2;
128 #endif
130 extern int wrapup_global_declarations PARAMS ((union tree_node **, int));
131 extern void check_global_declarations PARAMS ((union tree_node **, int));
132 extern void note_deferral_of_defined_inline_function
133 PARAMS ((union tree_node *));
134 extern void note_outlining_of_inline_function
135 PARAMS ((union tree_node *));
136 extern int errorcount;
137 extern int warningcount;
138 extern int sorrycount;
140 extern const char *progname;
141 extern const char *dump_base_name;
143 /* Language-specific hooks. Can be NULL unless otherwise specified. */
144 struct lang_hooks
146 /* Called first, to initialize the front end. */
147 void (*init) PARAMS ((void));
149 /* Called last, as a finalizer. */
150 void (*finish) PARAMS ((void));
152 /* Called to initialize options, before any calls to decode_option. */
153 void (*init_options) PARAMS ((void));
155 /* Function called with an option vector as argument, to decode a
156 single option (typically starting with -f or -W or +). It should
157 return the number of command-line arguments it uses if it handles
158 the option, or 0 and not complain if it does not recognise the
159 option. If this function returns a negative number, then its
160 absolute value is the number of command-line arguments used, but,
161 in addition, no language-independent option processing should be
162 done for this option.
164 This hook cannot be NULL. */
165 int (*decode_option) PARAMS ((int, char **));
167 /* Called when all command line options have been processed. */
168 void (*post_options) PARAMS ((void));
171 /* Each front end provides its own. */
172 extern struct lang_hooks lang_hooks;
174 #endif /* __GCC_TOPLEV_H */