X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=symbol_table.c;h=9d45de342d6dc1bb4aa60db5ca8a4f76274845af;hb=1b1b7cdc86ac07b9b79bfeb201a23d048aefcae6;hp=2f8f9dbc272dcb6bd09000cda8c5bcd90179350e;hpb=fd16b92f058181088a385c3224c8814831c006d3;p=cparser diff --git a/symbol_table.c b/symbol_table.c index 2f8f9db..9d45de3 100644 --- a/symbol_table.c +++ b/symbol_table.c @@ -1,6 +1,6 @@ /* * This file is part of cparser. - * Copyright (C) 2007-2008 Matthias Braun + * Copyright (C) 2007-2009 Matthias Braun * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -19,7 +19,9 @@ */ #include +#include "adt/strutil.h" #include "symbol_table_t.h" +#include "symbol_t.h" #include "token_t.h" #include "adt/hash_string.h" #include "adt/obst.h" @@ -29,14 +31,14 @@ struct obstack symbol_obstack; static inline void init_symbol_table_entry(symbol_t *entry, const char *string) { - entry->string = string; - entry->ID = T_IDENTIFIER; - entry->pp_ID = 0; - entry->declaration = NULL; + entry->string = string; + entry->ID = T_IDENTIFIER; + entry->pp_ID = TP_NULL; + entry->entity = NULL; + entry->pp_definition = NULL; } #define HashSet symbol_table_t -#define HashSetIterator symbol_table_iterator_t #define HashSetEntry symbol_table_hash_entry_t #define ValueType symbol_t* #define NullValue NULL @@ -44,35 +46,35 @@ void init_symbol_table_entry(symbol_t *entry, const char *string) #define KeyType const char * #define ConstKeyType const char * #define GetKey(value) (value)->string -#define InitData(this,value,key) { (value) = (ValueType) obstack_alloc(&symbol_obstack, sizeof(symbol_t)); init_symbol_table_entry((value), key); } +#define InitData(this,value,key) ((void)((value) = (ValueType)obstack_alloc(&symbol_obstack, sizeof(symbol_t)), init_symbol_table_entry((value), key))) #define Hash(this, key) hash_string(key) -#define KeysEqual(this,key1,key2) (strcmp(key1, key2) == 0) +#define KeysEqual(this,key1,key2) (streq(key1, key2)) #define SetRangeEmpty(ptr,size) memset(ptr, 0, (size) * sizeof(symbol_table_hash_entry_t)) +#define SCALAR_RETURN +void _symbol_table_init(symbol_table_t *symbol_table); #define hashset_init _symbol_table_init -#define hashset_init_size _symbol_table_init_size +void _symbol_table_destroy(symbol_table_t *symbol_table); #define hashset_destroy _symbol_table_destroy +symbol_t *_symbol_table_insert(symbol_table_t *symbol_table, const char *key); #define hashset_insert _symbol_table_insert -#define hashset_remove _symbol_table_remove -#define hashset_find _symbol_table_find -#define hashset_size _symbol_table_size -#define hashset_iterator_init _symbol_table_iterator_init -#define hashset_iterator_next _symbol_table_iterator_next -#define hashset_remove_iterator _symbol_table_remove_iterator -#include "adt/hashset.c" +#include "adt/hashset.c.inl" static symbol_table_t symbol_table; -symbol_t *symbol_table_insert(const char *symbol) +symbol_t *sym_anonymous; + +symbol_t *symbol_table_insert(const char *string) { - return _symbol_table_insert(&symbol_table, symbol); + return _symbol_table_insert(&symbol_table, string); } void init_symbol_table(void) { obstack_init(&symbol_obstack); _symbol_table_init(&symbol_table); + sym_anonymous = symbol_table_insert(""); } void exit_symbol_table(void)