1 /* Provide a call-back mechanism for handling error output.
2 Copyright (C) 1993, 1994, 1995 Free Software Foundation, Inc.
3 Contributed by Jason Merrill (jason@cygnus.com)
5 This file is part of GNU CC.
7 GNU CC 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)
12 GNU CC 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.
17 You should have received a copy of the GNU General Public License
18 along with GNU CC; see the file COPYING. If not, write to
19 the Free Software Foundation, 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA. */
26 /* cp_printer is the type of a function which converts an argument into
27 a string for digestion by printf. The cp_printer function should deal
28 with all memory management; the functions in this file will not free
29 the char*s returned. See error.c for an example use of this code. */
31 typedef char* cp_printer PROTO((HOST_WIDE_INT, int));
32 extern cp_printer * cp_printers[256];
34 /* Whether or not we should try to be quiet for errors and warnings; this is
35 used to avoid being too talkative about problems with tentative choices
36 when we're computing the conversion costs for a method call. */
39 typedef void errorfn (); /* deliberately vague */
41 extern char* cp_file_of PROTO((tree));
42 extern int cp_line_of PROTO((tree));
44 #define STRDUP(f) (ap = (char *) alloca (strlen (f) +1), strcpy (ap, (f)), ap)
47 #define arglist a1, a2, a3, a4
48 #define arglist_dcl HOST_WIDE_INT a1, a2, a3, a4;
49 #define ARGSINIT args[0] = a1; args[1] = a2; args[2] = a3; args[3] = a4;
50 #define ARGSLIST args[0], args[1], args[2], args[3]
53 cp_thing (errfn, atarg1, format, arglist)
63 HOST_WIDE_INT atarg = atarg1 ? a1 : 0;
64 HOST_WIDE_INT args[NARGS];
69 for (f = fmt, arg = 0; *f; ++f)
71 cp_printer * function;
76 if (*f != '%') continue;
83 /* ignore most flags */
84 while (*f == ' ' || *f == '-' || *f == '+' || *f == '#')
93 /* ignore field width */
103 /* ignore precision */
121 function = cp_printers[(int)*f];
127 if (arg >= NARGS) abort ();
129 if (maybe_here && atarg1)
132 /* Must use a temporary to avoid calling *function twice */
133 p = (*function) (args[arg], alternate);
134 args[arg] = (HOST_WIDE_INT) STRDUP(p);
138 ++arg; /* Assume valid format string */
144 char *file = cp_file_of ((tree) atarg);
145 int line = cp_line_of ((tree) atarg);
146 (*errfn) (file, line, fmt, ARGSLIST);
149 (*errfn) (fmt, ARGSLIST);
154 cp_error (format, arglist)
158 extern errorfn error;
160 cp_thing (error, 0, format, arglist);
164 cp_warning (format, arglist)
168 extern errorfn warning;
170 cp_thing (warning, 0, format, arglist);
174 cp_pedwarn (format, arglist)
178 extern errorfn pedwarn;
180 cp_thing (pedwarn, 0, format, arglist);
184 cp_compiler_error (format, arglist)
188 extern errorfn compiler_error;
190 cp_thing (compiler_error, 0, format, arglist);
194 cp_sprintf (format, arglist)
198 extern errorfn sprintf;
199 cp_thing (sprintf, 0, format, arglist);
203 cp_error_at (format, arglist)
207 extern errorfn error_with_file_and_line;
209 cp_thing (error_with_file_and_line, 1, format, arglist);
213 cp_warning_at (format, arglist)
217 extern errorfn warning_with_file_and_line;
219 cp_thing (warning_with_file_and_line, 1, format, arglist);
223 cp_pedwarn_at (format, arglist)
227 extern errorfn pedwarn_with_file_and_line;
229 cp_thing (pedwarn_with_file_and_line, 1, format, arglist);