X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=type_hash.c;h=a931f7db0add5297b2398fa386fedda20f048b6f;hb=86a26fbef4fa611787c8390a54955a9e998559b8;hp=7f2e30a365e66510937c64dd157233c4857e05bf;hpb=1812196339ccc8504067c431865679ac71d07512;p=cparser diff --git a/type_hash.c b/type_hash.c index 7f2e30a..a931f7d 100644 --- a/type_hash.c +++ b/type_hash.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 @@ -101,6 +101,7 @@ static unsigned hash_function_type(const function_type_t *type) result ^= hash_ptr(parameter->type); parameter = parameter->next; } + result += type->modifiers; result += type->linkage; result += type->calling_convention; @@ -120,14 +121,6 @@ static unsigned hash_typeof_type(const typeof_type_t *type) return result; } -static unsigned hash_bitfield_type(const bitfield_type_t *type) -{ - unsigned result = hash_ptr(type->base_type); - result ^= 27172145; - - return result; -} - static unsigned hash_type(const type_t *type) { unsigned hash = 0; @@ -165,23 +158,16 @@ static unsigned hash_type(const type_t *type) case TYPE_ARRAY: hash = hash_array_type(&type->array); break; - case TYPE_BUILTIN: - hash = hash_ptr(type->builtin.symbol); - break; case TYPE_TYPEDEF: hash = hash_ptr(type->typedeft.typedefe); break; case TYPE_TYPEOF: hash = hash_typeof_type(&type->typeoft); break; - case TYPE_BITFIELD: - hash = hash_bitfield_type(&type->bitfield); - break; } unsigned some_prime = 99991; hash ^= some_prime * type->base.qualifiers; - hash ^= some_prime * type->base.alignment; return hash; } @@ -217,6 +203,8 @@ static bool function_types_equal(const function_type_t *type1, return false; if (type1->linkage != type2->linkage) return false; + if (type1->modifiers != type2->modifiers) + return false; if (type1->calling_convention != type2->calling_convention) return false; @@ -269,12 +257,6 @@ static bool array_types_equal(const array_type_t *type1, return false; } -static bool builtin_types_equal(const builtin_type_t *type1, - const builtin_type_t *type2) -{ - return type1->symbol == type2->symbol; -} - static bool compound_types_equal(const compound_type_t *type1, const compound_type_t *type2) { @@ -304,15 +286,6 @@ static bool typeof_types_equal(const typeof_type_t *type1, return true; } -static bool bitfield_types_equal(const bitfield_type_t *type1, - const bitfield_type_t *type2) -{ - if (type1->base_type != type2->base_type) - return false; - /* TODO: compare size expression */ - return false; -} - static bool types_equal(const type_t *type1, const type_t *type2) { if (type1 == type2) @@ -321,10 +294,6 @@ static bool types_equal(const type_t *type1, const type_t *type2) return false; if (type1->base.qualifiers != type2->base.qualifiers) return false; - if (type1->base.modifiers != type2->base.modifiers) - return false; - if (type1->base.alignment != type2->base.alignment) - return false; switch (type1->kind) { case TYPE_ERROR: @@ -351,14 +320,10 @@ static bool types_equal(const type_t *type1, const type_t *type2) return reference_types_equal(&type1->reference, &type2->reference); case TYPE_ARRAY: return array_types_equal(&type1->array, &type2->array); - case TYPE_BUILTIN: - return builtin_types_equal(&type1->builtin, &type2->builtin); case TYPE_TYPEOF: return typeof_types_equal(&type1->typeoft, &type2->typeoft); case TYPE_TYPEDEF: return typedef_types_equal(&type1->typedeft, &type2->typedeft); - case TYPE_BITFIELD: - return bitfield_types_equal(&type1->bitfield, &type2->bitfield); } abort();