X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=entity_t.h;h=401b8b6c013077e45b5a144b78d20c55d8bc208d;hb=b8f4fc13774d296a361e9e80e813a7eb906fc54b;hp=364e6445541b48331ff343a1cb8a150094500f7d;hpb=9237a87907d3057e6014f4d326f03b16baed108a;p=cparser diff --git a/entity_t.h b/entity_t.h index 364e644..401b8b6 100644 --- a/entity_t.h +++ b/entity_t.h @@ -28,8 +28,7 @@ #include "builtins.h" typedef enum { - ENTITY_INVALID, - ENTITY_VARIABLE, + ENTITY_VARIABLE = 1, ENTITY_COMPOUND_MEMBER, ENTITY_PARAMETER, ENTITY_FUNCTION, @@ -46,8 +45,7 @@ typedef enum { typedef unsigned char entity_kind_t; typedef enum namespace_tag_t { - NAMESPACE_INVALID, - NAMESPACE_NORMAL, + NAMESPACE_NORMAL = 1, NAMESPACE_TAG, NAMESPACE_LABEL } namespace_tag_t; @@ -210,6 +208,8 @@ struct compound_member_t { declaration_t base; il_size_t offset; /**< the offset of this member in the compound */ unsigned char bit_offset; /**< extra bit offset for bitfield members */ + unsigned char bit_size; /**< bitsize for bitfield members */ + bool bitfield : 1; /**< member is (part of) a bitfield */ bool read : 1; bool address_taken : 1; /**< Set if the address of this declaration was taken. */ @@ -265,9 +265,13 @@ struct function_t { symbol_t *actual_name; /**< gnu extension __REDIRECT */ /* ast2firm info */ - ir_entity *irentity; - ir_node *static_link; /**< if need_closure is set, the node - representing the static link. */ + union { + ir_builtin_kind firm_builtin_kind; + unsigned chk_arg_pos; + } b; + ir_entity *irentity; + ir_node *static_link; /**< if need_closure is set, the node + representing the static link. */ }; union entity_t { @@ -286,16 +290,16 @@ union entity_t { compound_member_t compound_member; }; -#define DECLARATION_KIND_CASES \ - case ENTITY_FUNCTION: \ - case ENTITY_VARIABLE: \ - case ENTITY_PARAMETER: \ - case ENTITY_COMPOUND_MEMBER: +#define DECLARATION_KIND_CASES \ + ENTITY_FUNCTION: \ + case ENTITY_VARIABLE: \ + case ENTITY_PARAMETER: \ + case ENTITY_COMPOUND_MEMBER static inline bool is_declaration(const entity_t *entity) { switch(entity->kind) { - DECLARATION_KIND_CASES + case DECLARATION_KIND_CASES: return true; default: return false; @@ -304,8 +308,10 @@ static inline bool is_declaration(const entity_t *entity) const char *get_entity_kind_name(entity_kind_t kind); -entity_t *allocate_entity_zero(entity_kind_t kind); +entity_t *allocate_entity_zero(entity_kind_t, entity_namespace_t, symbol_t*); elf_visibility_tag_t get_elf_visibility_from_string(const char *string); +entity_t *skip_unnamed_bitfields(entity_t*); + #endif