Prevent warning about incompatible types when initializing a function like a variable...
[cparser] / ast_t.h
diff --git a/ast_t.h b/ast_t.h
index 477f92b..d014754 100644 (file)
--- a/ast_t.h
+++ b/ast_t.h
@@ -35,7 +35,7 @@ extern struct obstack ast_obstack;
 /**
  * Expression kinds.
  */
-typedef enum {
+typedef enum expression_kind_t {
        EXPR_UNKNOWN = 0,
        EXPR_INVALID,
        EXPR_REFERENCE,
@@ -76,8 +76,7 @@ typedef enum {
        EXPR_UNARY_CAST,
        EXPR_UNARY_CAST_IMPLICIT, /**< compiler generated cast */
        EXPR_UNARY_ASSUME,        /**< MS __assume() */
-       EXPR_UNARY_BITFIELD_EXTRACT,
-       EXPR_UNARY_LAST = EXPR_UNARY_BITFIELD_EXTRACT,
+       EXPR_UNARY_LAST = EXPR_UNARY_ASSUME,
 
        EXPR_BINARY_FIRST,
        EXPR_BINARY_ADD = EXPR_BINARY_FIRST,
@@ -121,7 +120,7 @@ typedef enum {
        EXPR_BINARY_LAST = EXPR_BINARY_ISUNORDERED,
 } expression_kind_t;
 
-typedef enum {
+typedef enum funcname_kind_t {
        FUNCNAME_FUNCTION,           /**< C99 __func__, older __FUNCTION__ */
        FUNCNAME_PRETTY_FUNCTION,    /**< GNUC __PRETTY_FUNCTION__ */
        FUNCNAME_FUNCSIG,            /**< MS __FUNCSIG__ */
@@ -181,8 +180,7 @@ typedef enum {
        case EXPR_UNARY_PREFIX_DECREMENT:      \
        case EXPR_UNARY_CAST:                  \
        case EXPR_UNARY_CAST_IMPLICIT:         \
-       case EXPR_UNARY_ASSUME:                \
-       case EXPR_UNARY_BITFIELD_EXTRACT:
+       case EXPR_UNARY_ASSUME:
 
 /**
  * A scope containing declarations.
@@ -196,6 +194,9 @@ struct expression_base_t {
        expression_kind_t   kind;
        type_t             *type;
        source_position_t   source_position;
+#ifndef NDEBUG
+       bool                transformed;
+#endif
 };
 
 struct const_expression_t {
@@ -251,7 +252,6 @@ struct builtin_prefetch_expression_t {
 
 struct reference_expression_t {
        expression_base_t  base;
-       symbol_t          *symbol;
        declaration_t     *declaration;
 };
 
@@ -280,8 +280,6 @@ struct binary_expression_t {
 struct select_expression_t {
        expression_base_t  base;
        expression_t      *compound;
-       symbol_t          *symbol;
-
        declaration_t     *compound_entry;
 };
 
@@ -365,7 +363,7 @@ union expression_t {
        classify_type_expression_t       classify_type;
 };
 
-typedef enum {
+typedef enum storage_class_tag_t {
        STORAGE_CLASS_NONE,
        STORAGE_CLASS_EXTERN,
        STORAGE_CLASS_STATIC,
@@ -378,7 +376,7 @@ typedef enum {
        STORAGE_CLASS_THREAD_STATIC,
 } storage_class_tag_t;
 
-typedef enum {
+typedef enum namespace_t {
        NAMESPACE_NORMAL,
        NAMESPACE_STRUCT,
        NAMESPACE_UNION,
@@ -386,7 +384,7 @@ typedef enum {
        NAMESPACE_LABEL,
 } namespace_t;
 
-typedef enum {
+typedef enum initializer_kind_t {
        INITIALIZER_VALUE,
        INITIALIZER_LIST,
        INITIALIZER_STRING,
@@ -486,6 +484,8 @@ typedef enum gnu_attribute_kind_t {
        GNU_AK_MAY_ALIAS,
        GNU_AK_MS_STRUCT,
        GNU_AK_GCC_STRUCT,
+       GNU_AK_DLLIMPORT,
+       GNU_AK_DLLEXPORT,
        GNU_AK_ALIGNED,
        GNU_AK_ALIAS,
        GNU_AK_SECTION,
@@ -497,6 +497,7 @@ typedef enum gnu_attribute_kind_t {
        GNU_AK_VISIBILITY,
        GNU_AK_REGPARM,
        GNU_AK_MODEL,
+       GNU_AK_MODE,
        GNU_AK_TRAP_EXIT,
        GNU_AK_SP_SWITCH,
        GNU_AK_SENTINEL,
@@ -506,48 +507,60 @@ typedef enum gnu_attribute_kind_t {
 /**
  * Extended microsoft modifier.
  */
-typedef enum {
-       DM_DLLIMPORT        = (1 <<  0),
-       DM_DLLEXPORT        = (1 <<  1),
-       DM_THREAD           = (1 <<  2),
-       DM_NAKED            = (1 <<  3),
-       DM_MICROSOFT_INLINE = (1 <<  4),
-       DM_FORCEINLINE      = (1 <<  5),
-       DM_SELECTANY        = (1 <<  6),
-       DM_NOTHROW          = (1 <<  7),
-       DM_NOVTABLE         = (1 <<  8),
-       DM_NORETURN         = (1 <<  9),
-       DM_NOINLINE         = (1 << 10),
-       DM_RESTRICT         = (1 << 11),
-       DM_NOALIAS          = (1 << 12)
+typedef enum decl_modifier_t {
+       DM_DLLIMPORT         = 1 <<  0,
+       DM_DLLEXPORT         = 1 <<  1,
+       DM_THREAD            = 1 <<  2,
+       DM_NAKED             = 1 <<  3,
+       DM_MICROSOFT_INLINE  = 1 <<  4,
+       DM_FORCEINLINE       = 1 <<  5,
+       DM_SELECTANY         = 1 <<  6,
+       DM_NOTHROW           = 1 <<  7,
+       DM_NOVTABLE          = 1 <<  8,
+       DM_NORETURN          = 1 <<  9,
+       DM_NOINLINE          = 1 << 10,
+       DM_RESTRICT          = 1 << 11,
+       DM_NOALIAS           = 1 << 12,
+       DM_PACKED            = 1 << 13,
+       DM_TRANSPARENT_UNION = 1 << 14,
+       DM_PURE              = 1 << 15,
+       DM_CONSTRUCTOR       = 1 << 16,
+       DM_DESTRUCTOR        = 1 << 17,
+       DM_UNUSED            = 1 << 18,
+       DM_USED              = 1 << 19,
+       DM_CDECL             = 1 << 20,
+       DM_FASTCALL          = 1 << 21,
+       DM_STDCALL           = 1 << 22,
+       DM_THISCALL          = 1 << 23,
+       DM_DEPRECATED        = 1 << 24
 } decl_modifier_t;
 
-typedef unsigned short decl_modifiers_t;
+typedef unsigned decl_modifiers_t;
 
 struct declaration_t {
        unsigned char       namespc;
        unsigned char       declared_storage_class;
        unsigned char       storage_class;
        unsigned char       alignment;          /**< Alignment of the declaration, 0 for default. */
-       decl_modifiers_t    modifiers;          /**< MS __declspec modifiers. */
+       decl_modifiers_t    modifiers;          /**< modifiers. */
        const char         *deprecated_string;  /**< MS deprecated string if any. */
        symbol_t           *get_property_sym;   /**< MS get property. */
        symbol_t           *put_property_sym;   /**< MS put property. */
        unsigned int        address_taken : 1;
        unsigned int        is_inline     : 1;
        unsigned int        used          : 1;  /**< Set if the declaration is used. */
-       unsigned int        deprecated    : 1;  /**< Microsoft of GNU deprecated attribute. */
+       unsigned int        implicit      : 1;
        type_t             *type;
        symbol_t           *symbol;
        source_position_t   source_position;
        union {
-               bool            is_defined;
+               bool            complete;           /**< used to indicate whether struct/union types are already defined or if just the name is declared */
                statement_t    *statement;
                initializer_t  *initializer;
                expression_t   *enum_value;
        } init;
        scope_t             scope;              /**< The scope that this declaration opens. */
-       scope_t            *parent_scope;       /**< The parant scope where this declaration lives. */
+       scope_t            *parent_scope;       /**< The parent scope where this declaration lives. */
 
        /** next declaration in a scope */
        declaration_t      *next;
@@ -566,7 +579,7 @@ struct declaration_t {
        } v;
 };
 
-typedef enum {
+typedef enum statement_kind_t {
        STATEMENT_INVALID,
        STATEMENT_EMPTY,
        STATEMENT_COMPOUND,
@@ -583,13 +596,20 @@ typedef enum {
        STATEMENT_WHILE,
        STATEMENT_DO_WHILE,
        STATEMENT_FOR,
-       STATEMENT_ASM
+       STATEMENT_ASM,
+       STATEMENT_MS_TRY,
+       STATEMENT_LEAVE
 } statement_kind_t;
 
 struct statement_base_t {
        statement_kind_t   kind;
        statement_t       *next;
        source_position_t  source_position;
+       statement_t       *parent;
+       bool               reachable;
+#ifndef NDEBUG
+       bool               transformed;
+#endif
 };
 
 struct invalid_statement_t {
@@ -625,10 +645,12 @@ struct if_statement_t {
 };
 
 struct switch_statement_t {
-       statement_base_t       base;
+       statement_base_t        base;
        expression_t           *expression;
        statement_t            *body;
-       case_label_statement_t *first_case, *last_case;
+       case_label_statement_t *first_case, *last_case;  /**< List of all cases, including default. */
+       case_label_statement_t *default_label;    /**< The default label if existent. */
+       unsigned long           default_proj_nr;  /**< The Proj-number for the default Proj. */
 };
 
 struct goto_statement_t {
@@ -641,8 +663,12 @@ struct case_label_statement_t {
        statement_base_t        base;
        expression_t           *expression;  /**< The case label expression, NULL for default label. */
        expression_t           *end_range;   /**< For GNUC case a .. b: the end range expression, NULL else. */
+       case_label_statement_t *next;        /**< link to the next case label in switch */
        statement_t            *statement;
-       case_label_statement_t *next; /**< link to the next case label in switch */
+       long                   first_case;   /**< The folded value of expression. */
+       long                   last_case;    /**< The folded value of end_range. */
+       bool                   is_bad;       /**< If set marked as bad to supress warnings. */
+       bool                   is_empty;     /**< If set marked this is a empty range. */
 };
 
 struct label_statement_t {
@@ -676,13 +702,15 @@ struct for_statement_t {
        expression_t     *step;
        statement_t      *body;
        scope_t           scope;
+       bool              condition_reachable:1;
+       bool              step_reachable:1;
 };
 
-struct asm_constraint_t {
-       string_t          constraints;
-       expression_t     *expression;
-       symbol_t         *symbol;
-       asm_constraint_t *next;
+struct asm_argument_t {
+       string_t        constraints;
+       expression_t   *expression;
+       symbol_t       *symbol;
+       asm_argument_t *next;
 };
 
 struct asm_clobber_t {
@@ -691,12 +719,23 @@ struct asm_clobber_t {
 };
 
 struct asm_statement_t {
+       statement_base_t base;
+       string_t         asm_text;
+       asm_argument_t  *inputs;
+       asm_argument_t  *outputs;
+       asm_clobber_t   *clobbers;
+       bool             is_volatile;
+};
+
+struct ms_try_statement_t {
+       statement_base_t  base;
+       statement_t      *try_statement;
+       expression_t     *except_expression; /**< non-null for except, NULL for finally */
+       statement_t      *final_statement;
+};
+
+struct leave_statement_t {
        statement_base_t  base;
-       string_t          asm_text;
-       asm_constraint_t *inputs;
-       asm_constraint_t *outputs;
-       asm_clobber_t    *clobbers;
-       bool              is_volatile;
 };
 
 union statement_t {
@@ -715,10 +754,13 @@ union statement_t {
        do_while_statement_t     do_while;
        for_statement_t          fors;
        asm_statement_t          asms;
+       ms_try_statement_t       ms_try;
+       leave_statement_t        leave;
 };
 
 struct translation_unit_t {
-       scope_t scope;
+       scope_t      scope;
+       statement_t *global_asm;
 };
 
 static inline