X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=entity.c;h=528e3a15d949cc11fe4a8a2f23a4736bf683d0d3;hb=b8f4fc13774d296a361e9e80e813a7eb906fc54b;hp=89d69e373c8a649d09c4fbad9c51d5fea100082e;hpb=9237a87907d3057e6014f4d326f03b16baed108a;p=cparser diff --git a/entity.c b/entity.c index 89d69e3..528e3a1 100644 --- a/entity.c +++ b/entity.c @@ -43,7 +43,6 @@ const char *get_entity_kind_name(entity_kind_t kind) case ENTITY_LOCAL_LABEL: return "local label"; case ENTITY_TYPEDEF: return "typedef"; case ENTITY_NAMESPACE: return "namespace"; - case ENTITY_INVALID: break; } panic("Invalid entity kind encountered in get_entity_kind_name"); @@ -81,11 +80,13 @@ static size_t get_entity_struct_size(entity_kind_t kind) * * @param kind the kind of the entity to allocate */ -entity_t *allocate_entity_zero(entity_kind_t kind) +entity_t *allocate_entity_zero(entity_kind_t const kind, entity_namespace_t const namespc, symbol_t *const symbol) { - size_t size = get_entity_struct_size(kind); - entity_t *entity = allocate_ast_zero(size); - entity->kind = kind; + size_t size = get_entity_struct_size(kind); + entity_t *entity = allocate_ast_zero(size); + entity->kind = kind; + entity->base.namespc = namespc; + entity->base.symbol = symbol; return entity; } @@ -103,3 +104,13 @@ elf_visibility_tag_t get_elf_visibility_from_string(const char *string) return ELF_VISIBILITY_ERROR; } } + +entity_t *skip_unnamed_bitfields(entity_t *entry) +{ + for (; entry != NULL; entry = entry->base.next) { + assert(entry->kind == ENTITY_COMPOUND_MEMBER); + if (!entry->compound_member.bitfield || entry->base.symbol != NULL) + break; + } + return entry; +}