/**
* Expression kinds.
*/
-typedef enum {
+typedef enum expression_kind_t {
EXPR_UNKNOWN = 0,
EXPR_INVALID,
EXPR_REFERENCE,
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,
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__ */
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.
expression_kind_t kind;
type_t *type;
source_position_t source_position;
+#ifndef NDEBUG
+ bool transformed;
+#endif
};
struct const_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,
STORAGE_CLASS_THREAD_STATIC,
} storage_class_tag_t;
-typedef enum {
+typedef enum namespace_t {
NAMESPACE_NORMAL,
NAMESPACE_STRUCT,
NAMESPACE_UNION,
NAMESPACE_LABEL,
} namespace_t;
-typedef enum {
+typedef enum initializer_kind_t {
INITIALIZER_VALUE,
INITIALIZER_LIST,
INITIALIZER_STRING,
/**
* 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 decl_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 or GNU deprecated attribute. */
- unsigned int valid : 1; /**< declaration is valid (=no syntax errors) */
+ unsigned int implicit : 1;
type_t *type;
symbol_t *symbol;
source_position_t source_position;
union {
- bool complete; /**< used to indicate wether struct/union types are already defined or if just the name is declared */
+ 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;
} v;
};
-typedef enum {
+typedef enum statement_kind_t {
STATEMENT_INVALID,
STATEMENT_EMPTY,
STATEMENT_COMPOUND,
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 {
};
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 {
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 {
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 {
};
struct asm_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;
+ 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 {
};
struct translation_unit_t {
- scope_t scope;
+ scope_t scope;
+ statement_t *global_asm;
};
static inline