X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=types.c;h=ff45f8abaa502be1fd221aa45d43c13e42b51317;hb=cf05b05984fbf8be1553541967ec5964d0ee5b8f;hp=53b78b5a5bbef99d06942c30f38f87778ad6bb3b;hpb=b6896812e8b666bd893a13948a838dedb011282b;p=cparser diff --git a/types.c b/types.c index 53b78b5..ff45f8a 100644 --- a/types.c +++ b/types.c @@ -1,6 +1,8 @@ #include "type_t.h" #include "types.h" +/** The error type. */ +type_t *type_error_type; type_t *type_char; type_t *type_double; @@ -11,12 +13,12 @@ type_t *type_long_long; type_t *type_long; type_t *type_short; type_t *type_signed_char; -type_t *type_string; type_t *type_unsigned_int; type_t *type_unsigned_long_long; type_t *type_unsigned_long; type_t *type_void; +type_t *type_char_ptr; type_t *type_int_ptr; type_t *type_long_long_ptr; type_t *type_long_ptr; @@ -24,6 +26,8 @@ type_t *type_short_ptr; type_t *type_signed_char_ptr; type_t *type_void_ptr; +type_t *type_char_ptr_ptr; + type_t *type_intmax_t; type_t *type_ptrdiff_t; type_t *type_size_t; @@ -41,6 +45,9 @@ type_t *type_wchar_t_ptr; void init_basic_types(void) { + static const type_base_t error = { TYPE_ERROR, TYPE_QUALIFIER_NONE, { NULL, 0 }, NULL }; + + type_error_type = (type_t*)&error; type_signed_char = make_atomic_type(ATOMIC_TYPE_SCHAR, TYPE_QUALIFIER_NONE); type_short = make_atomic_type(ATOMIC_TYPE_SHORT, TYPE_QUALIFIER_NONE); type_int = make_atomic_type(ATOMIC_TYPE_INT, TYPE_QUALIFIER_NONE); @@ -56,10 +63,12 @@ void init_basic_types(void) type_void = make_atomic_type(ATOMIC_TYPE_VOID, TYPE_QUALIFIER_NONE); type_void_ptr = make_pointer_type(type_void, TYPE_QUALIFIER_NONE); - type_string = make_pointer_type(type_char, TYPE_QUALIFIER_NONE); + type_char_ptr = make_pointer_type(type_char, TYPE_QUALIFIER_NONE); type_signed_char_ptr = make_pointer_type(type_signed_char, TYPE_QUALIFIER_NONE); type_short_ptr = make_pointer_type(type_short, TYPE_QUALIFIER_NONE); type_int_ptr = make_pointer_type(type_int, TYPE_QUALIFIER_NONE); type_long_ptr = make_pointer_type(type_long, TYPE_QUALIFIER_NONE); type_long_long_ptr = make_pointer_type(type_long_long, TYPE_QUALIFIER_NONE); + + type_char_ptr_ptr = make_pointer_type(type_char_ptr, TYPE_QUALIFIER_NONE); }