X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/23eb2a692f2e966c840d5f953de4bf8e26d71225..a17187e56386747a9b4d9633c3d116c2087f2b8b:/src/complain.h?ds=sidebyside diff --git a/src/complain.h b/src/complain.h index fe23eb9f..e27b40d3 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, 2006 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,20 +14,26 @@ 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, - USA. */ + along with this program. If not, see . */ #ifndef COMPLAIN_H_ # define COMPLAIN_H_ 1 # include "location.h" -# ifdef __cplusplus +# ifdef __cplusplus extern "C" { # endif -/** Informative messages, but we proceed. */ +/** 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,6 +41,13 @@ void warn (char const *format, ...) void warn_at (location loc, char const *format, ...) __attribute__ ((__format__ (__printf__, 2, 3))); +/* 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, ...) @@ -41,6 +56,25 @@ void complain (char const *format, ...) void complain_at (location loc, char const *format, ...) __attribute__ ((__format__ (__printf__, 2, 3))); +/* 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, ...) @@ -52,7 +86,7 @@ void fatal_at (location loc, char const *format, ...) /** Whether an error was reported. */ extern bool complaint_issued; -# ifdef __cplusplus +# ifdef __cplusplus } # endif