X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/ea03c24f0554fb77d73dd6c183b5bde44a6c9570..b7226022b07fac385defbf2297892d8c3dc3cd18:/src/complain.h diff --git a/src/complain.h b/src/complain.h index b9b00c66..997d577b 100644 --- a/src/complain.h +++ b/src/complain.h @@ -1,10 +1,12 @@ /* Declaration for error-reporting function for Bison. - Copyright (C) 2000, 2001, 2002 Free Software Foundation, Inc. - This program 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. + Copyright (C) 2000-2002, 2006, 2009-2012 Free Software Foundation, + Inc. + + This program 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 3 of the License, or + (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -12,9 +14,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, - USA. */ + along with this program. If not, see . */ #ifndef COMPLAIN_H_ # define COMPLAIN_H_ 1 @@ -25,7 +25,18 @@ extern "C" { # endif -/* Informative messages, but we proceed. */ +/* Sub-messages indent. */ +#define SUB_INDENT (4) + +/** Record that a warning is about to be issued, and treat it as an + error if warnings_flag & warnings_error. This is exported + only for the sake of Yacc-compatible conflict reports in conflicts.c. + All other warnings should be implemented in complain.c and should use + the normal warning format. */ +void set_warning_issued (void); + +/** Informative messages, but we proceed. Report iff + warnings_flag & warnings_other. */ void warn (char const *format, ...) __attribute__ ((__format__ (__printf__, 1, 2))); @@ -33,7 +44,14 @@ void warn (char const *format, ...) void warn_at (location loc, char const *format, ...) __attribute__ ((__format__ (__printf__, 2, 3))); -/* Something bad happened, but let's continue and die later. */ +/* Generate a message aligned by an indent. + When *indent == 0, assign message's indent to *indent, + When *indent > 0, align the message by *indent value. */ +void warn_at_indent (location loc, unsigned *indent, + char const *format, ...) + __attribute__ ((__format__ (__printf__, 3, 4))); + +/** An error, but we continue and die later. */ void complain (char const *format, ...) __attribute__ ((__format__ (__printf__, 1, 2))); @@ -41,7 +59,26 @@ void complain (char const *format, ...) void complain_at (location loc, char const *format, ...) __attribute__ ((__format__ (__printf__, 2, 3))); -/* Something bad happened, and let's die now. */ +/* Generate a message aligned by an indent. + When *indent == 0, assign message's indent to *indent, + When *indent > 0, align the message by *indent value. */ +void complain_at_indent (location loc, unsigned *indent, + char const *format, ...) + __attribute__ ((__format__ (__printf__, 3, 4))); + +/** An incompatibility with POSIX Yacc: mapped either to warn* or + complain* depending on yacc_flag. */ + +void yacc_at (location loc, char const *format, ...) + __attribute__ ((__format__ (__printf__, 2, 3))); + +/** A midrule-value warning. Report iff + warnings_flag & warnings_midrule_values. */ + +void midrule_value_at (location loc, char const *format, ...) + __attribute__ ((__format__ (__printf__, 2, 3))); + +/** A fatal error, causing immediate exit. */ void fatal (char const *format, ...) __attribute__ ((__noreturn__, __format__ (__printf__, 1, 2))); @@ -49,10 +86,7 @@ void fatal (char const *format, ...) void fatal_at (location loc, char const *format, ...) __attribute__ ((__noreturn__, __format__ (__printf__, 2, 3))); -/* This variable is set each time `warn' is called. */ -extern bool warning_issued; - -/* This variable is set each time `complain' is called. */ +/** Whether an error was reported. */ extern bool complaint_issued; # ifdef __cplusplus