X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/808e523db40335778897b413d446dff1d41d0e85..fea2516636dfcf73e92c24b68804ffe7666086c1:/src/complain.h diff --git a/src/complain.h b/src/complain.h index c7f93e1e..0d81503d 100644 --- a/src/complain.h +++ b/src/complain.h @@ -35,6 +35,7 @@ typedef enum warning_yacc, /**< POSIXME. */ warning_conflicts_sr, /**< S/R conflicts. */ warning_conflicts_rr, /**< R/R conflicts. */ + warning_empty_rule, /**< Implicitly empty rules. */ warning_deprecated, /**< Obsolete constructs. */ warning_precedence, /**< Useless precedence and associativity. */ warning_other, /**< All other warnings. */ @@ -42,6 +43,39 @@ typedef enum warnings_size /**< The number of warnings. Must be last. */ } warning_bit; +/** Whether -Werror was set. */ +extern bool warnings_are_errors; + +/** Decode a single argument from -W. + * + * \param arg the subarguments to decode. + * If null, then activate all the flags. + * \param no length of the potential "no-" prefix. + * Can be 0 or 3. If 3, negate the action of the subargument. + * \param err length of a potential "error=". + * Can be 0 or 6. If 6, treat the subargument as a CATEGORY. + * + * If VALUE != 0 then KEY sets flags and no-KEY clears them. + * If VALUE == 0 then KEY clears all flags from \c all and no-KEY sets all + * flags from \c all. Thus no-none = all and no-all = none. + */ +void warning_argmatch (char const *arg, size_t no, size_t err); + +/** Decode a comma-separated list of arguments from -W. + * + * \param args comma separated list of effective subarguments to decode. + * If 0, then activate all the flags. + */ +void warnings_argmatch (char *args); + + +/*-----------. +| complain. | +`-----------*/ + +/** Initialize this module. */ +void complain_init (void); + typedef enum { /**< Issue no warnings. */ @@ -52,6 +86,7 @@ typedef enum Wconflicts_sr = 1 << warning_conflicts_sr, Wconflicts_rr = 1 << warning_conflicts_rr, Wdeprecated = 1 << warning_deprecated, + Wempty_rule = 1 << warning_empty_rule, Wprecedence = 1 << warning_precedence, Wother = 1 << warning_other, @@ -63,28 +98,13 @@ typedef enum no_caret = 1 << 14, /**< Do not display caret location. */ /**< All above warnings. */ - Wall = ~complaint & ~fatal & ~silent + Weverything = ~complaint & ~fatal & ~silent, + Wall = Weverything & ~Wyacc } warnings; - -/** For each warning type, its severity. */ -typedef enum - { - severity_disabled = 0, - severity_unset = 1, - severity_warning = 2, - severity_error = 3, - severity_fatal = 4 - } severity; - -/** Whether -Werror was set. */ -extern bool warnings_are_errors; - -/** For each warning type, its severity. */ -extern severity warnings_flag[]; - -/** Initialize this module. */ -void complain_init (void); +/** Whether the warnings of \a flags are all unset. + (Never enabled, never disabled). */ +bool warning_is_unset (warnings flags); /** Make a complaint, with maybe a location. */ void complain (location const *loc, warnings flags, char const *message, ...) @@ -104,6 +124,10 @@ void complain_indent (location const *loc, warnings flags, unsigned *indent, void deprecated_directive (location const *loc, char const *obsolete, char const *updated); +/** Report a repeated directive for a rule. */ +void duplicate_directive (char const *directive, + location first, location second); + /** Warnings treated as errors shouldn't stop the execution as regular errors should (because due to their nature, it is safe to go on). Thus, there are three possible execution statuses. */