type: Make an assert()ion independent of the last entry of an enum.
[cparser] / warning.h
1 /*
2  * This file is part of cparser.
3  * Copyright (C) 2012 Matthias Braun <matze@braunis.de>
4  */
5 #ifndef WARNING_H
6 #define WARNING_H
7
8 #include <stdbool.h>
9
10 void set_warning_opt(const char *opt);
11
12 void disable_all_warnings(void);
13
14 void print_warning_opt_help(void);
15
16 typedef enum warning_t {
17         WARN_ADDRESS,                       /**< Warn about suspicious uses of memory addresses */
18         WARN_AGGREGATE_RETURN,              /**< Warn if any functions that return structures or unions are defined or called */
19         WARN_ATTRIBUTE,                     /**< Warn if an unexpected `__attribute__' is used or function attributes applied to variables, etc. */
20 #if 0 // TODO
21         WARN_BAD_FUNCTION_CAST,             /**< Warn whenever a function call is cast to a non-matching type */
22         WARN_CAST_ALIGN,                    /**< Warn whenever a pointer is cast such that the required alignment of the target is increased */
23 #endif
24         WARN_CAST_QUAL,                     /**< Warn whenever a pointer is cast so as to remove a type qualifier from the target type */
25         WARN_CHAR_SUBSCRIPTS,               /**< Warn if an array subscript has the type 'char' */
26         WARN_COMMENT,                       /**< Warn whenever a comment-start sequence appears in a comment, or whenever a Backslash-Newline appears in a '//' comment. */
27         WARN_CONVERSION,                    /**< Warn if a prototype causes a type conversion that is different from what would happen to the same argument in the absence of a prototype */
28 #if 0 // TODO
29         WARN_CPP_COMPAT,                    /**< Warn about ISO C constructs that are outside of the common subset of ISO C and ISO C++. */
30 #endif
31         WARN_DECLARATION_AFTER_STATEMENT,   /**< Warn when a declaration is found after a statement in a block */
32         WARN_DEPRECATED_DECLARATIONS,       /* TODO implement for types */ /**< Warn about uses of functions, variables and types marked as deprecated by using the 'deprecated' attribute */
33         WARN_DIV_BY_ZERO,                   /**< Warn about compile-time integer division by zero */
34         WARN_EMPTY_BODY,                    /**< Warn about an empty body of an if or else statement */
35         WARN_EMPTY_STATEMENT,               /**< Warn about empty statements, i.e. lone ';'  */
36 #if 0 // TODO
37         WARN_ENDIF_LABELS,                  /**< Warn whenever an '#else' or an '#endif' are followed by text */
38 #endif
39         WARN_ERROR,                         /**< Treat warnings as errors */
40         WARN_FATAL_ERRORS,                  /**< First error stops the compilation */
41         WARN_FLOAT_EQUAL,                   /**< Warn if floating point values are used in equality comparisons */
42         WARN_FORMAT,                        /**< Check printf-style format strings */
43         WARN_IGNORED_QUALIFIERS,            /**< Warn when type qualifiers are meaningless */
44         WARN_IMPLICIT_FUNCTION_DECLARATION, /**< Warn whenever a function is used before being declared */
45         WARN_IMPLICIT_INT,                  /**< Warn when a declaration does not specify a type */
46 #if 0 // TODO
47         WARN_INLINE,                        /**< Warn if a function can not be inlined and it was declared as inline */
48         WARN_INT_TO_POINTER_CAST,           /**< Warn if cast from integer to pointer of different size. */
49 #endif
50         WARN_LONG_LONG,                     /**< Warn if 'long long' type is used */
51         WARN_MAIN,                          /**< Warn if the type of 'main' is suspicious */
52 #if 0 // TODO
53         WARN_MISSING_BRACES,                /**< Warn if an aggregate or union initializer is not fully bracketed */
54 #endif
55         WARN_MISSING_DECLARATIONS,          /**< Warn if a global function is defined without a previous declaration */
56 #if 0 // TODO
57         WARN_MISSING_FIELD_INITIALIZERS,    /**< Warn if a structure's initializer has some fields missing. */
58         WARN_MISSING_FORMAT_ATTRIBUTE,      /**< If '-Wformat' is enabled, also warn about functions which might be candidates for 'format' attributes */
59 #endif
60         WARN_MISSING_NORETURN,              /**< Warn about functions which might be candidates for attribute 'noreturn' */
61         WARN_MISSING_PROTOTYPES,            /**< Warn if a global function is defined without a previous prototype declaration */
62         WARN_MULTICHAR,                     /**< Warn if a multicharacter constant ('FOOF') is used. */
63         WARN_NESTED_EXTERNS,                /**< Warn if an 'extern' declaration is encountered within a function. */
64         WARN_NONNULL,                       /**< Warn about passing a null pointer for arguments marked nonnull. */
65         WARN_OLD_STYLE_DEFINITION,          /**< Warn if an old-style function definition is used. */
66         WARN_OTHER,                         /**< Warnings not covered by any other option */
67         WARN_PACKED,                        /**< Warn if a structure is given the packed attribute, but the packed attribute has no effect on the layout or size of the structure */
68         WARN_PADDED,                        /**< Warn if padding is included in a structure, either to align an element of the structure or to align the whole structure */
69         WARN_PARENTHESES,                   /**< Warn if parentheses are omitted in certain contexts (assignment where truth value is expected, if-else-braces) */
70         WARN_POINTER_ARITH,                 /**< Warn about anything that depends on the "size of" a function type or of 'void' */
71 #if 0 // TODO
72         WARN_POINTER_TO_INT_CAST,           /**< Warn if cast from pointer to integer of different size. */
73 #endif
74         WARN_REDUNDANT_DECLS,               /**< Warn about redundant declarations */
75         WARN_RETURN_TYPE,                   /* TODO not fully implemented */ /**< Warn about function definitions with a return-type that defaults to 'int'.  Also warn about any 'return' statement with no return-value in a function whose return-type is not 'void'. */
76 #if 0 // TODO
77         WARN_SEQUENCE_POINT,                /**< Warn about code that may have undefined semantics because of violations of sequence point rules */
78 #endif
79         WARN_SHADOW,                        /**< Warn whenever a local variable shadows another local variable, parameter or global variable or whenever a built-in function is shadowed */
80         WARN_SHADOW_LOCAL,
81         WARN_SIGN_COMPARE,                  /**< Warn when a comparison between signed and unsigned values could produce an incorrect result when the signed value is converted to unsigned */
82         WARN_STRAY_SEMICOLON,               /**< Warn about stray semicolons outside of functions */
83 #if 0 // TODO
84         WARN_STRICT_ALIASING,               /**< Warn about code which might break the strict aliasing rules that the compiler is using for optimization. */
85 #endif
86         WARN_STRICT_PROTOTYPES,             /**< Warn if a function declaration has an unspecified parameter list */
87         WARN_SWITCH_DEFAULT,                /**< Warn whenever a 'switch' statement does not have a 'default' case */
88         WARN_SWITCH_ENUM,                   /**< Warn about 'switch' statements with an enum as index type and missing case labels or case labels outside the enum range TODO has an alias -Wswitch? */
89         WARN_SYSTEM,                        /**< Show warnings in system headers. */
90         WARN_TRADITIONAL,                   /**< Warn about certain constructs that behave differently in traditional and ISO C */
91 #if 0 // TODO
92         WARN_UNDEF,                         /**< Warn if an undefined identifier is evaluated in an '#if' directive */
93 #endif
94         WARN_UNINITIALIZED,                 /**< Warn if an automatic variable is used without being initialized or if a variable may be clobbered by a 'setjmp' call. */
95         WARN_UNKNOWN_PRAGMAS,               /**< Warn when a #pragma directive is encountered which is not understood */
96         WARN_UNREACHABLE_CODE,              /**< Warn if the compiler detects that code will never be executed */
97         WARN_UNUSED_FUNCTION,               /**< Warn whenever a static function is declared but not defined or a non-inline static function is unused */
98         WARN_UNUSED_LABEL,                  /**< Warn whenever a label is declared but not used */
99         WARN_UNUSED_PARAMETER,              /**< Warn whenever a function parameter is unused aside from its declaration */
100         WARN_UNUSED_VALUE,                  /**< Warn whenever a statement computes a result that is explicitly not used */
101         WARN_UNUSED_VARIABLE,               /**< Warn whenever a local variable or non-constant static variable is unused aside from its declaration */
102         WARN_WRITE_STRINGS,                 /**< Give string constants the type 'const char[LENGTH]' so that copying the address of one into a 'char *' pointer will get a warning */
103 } warning_t;
104
105 typedef enum warn_state_t {
106         WARN_STATE_NONE     = 0,
107         WARN_STATE_ON       = 1U << 0,
108         WARN_STATE_ERROR    = 1U << 1,
109         WARN_STATE_NO_ERROR = 1U << 2
110 } warn_state_t;
111
112 typedef struct warning_switch_t {
113         warn_state_t      state;
114         char const* const name;
115 } warning_switch_t;
116
117 warning_switch_t const *get_warn_switch(warning_t);
118
119 static inline bool is_warn_on(warning_t const warn)
120 {
121         return get_warn_switch(warn)->state & WARN_STATE_ON;
122 }
123
124 #endif