Small cleanup.
[cparser] / types.c
diff --git a/types.c b/types.c
index 578b342..0842ba2 100644 (file)
--- a/types.c
+++ b/types.c
 #include "type_t.h"
 #include "types.h"
 #include "lang_features.h"
+#include "entity_t.h"
 
 /** The error type. */
 type_t *type_error_type;
 
+type_t *type_bool;
 type_t *type_char;
 type_t *type_const_char;
 type_t *type_double;
@@ -35,6 +37,7 @@ type_t *type_long;
 type_t *type_short;
 type_t *type_unsigned_short;
 type_t *type_signed_char;
+type_t *type_unsigned_char;
 type_t *type_unsigned_int;
 type_t *type_unsigned_long_long;
 type_t *type_unsigned_long;
@@ -95,7 +98,9 @@ void init_basic_types(void)
                                           TYPE_MODIFIER_NONE, 0, NULL };
 
        type_error_type         = (type_t*)&error;
+       type_bool               = make_atomic_type(ATOMIC_TYPE_BOOL,        TYPE_QUALIFIER_NONE);
        type_signed_char        = make_atomic_type(ATOMIC_TYPE_SCHAR,       TYPE_QUALIFIER_NONE);
+       type_unsigned_char      = make_atomic_type(ATOMIC_TYPE_UCHAR,       TYPE_QUALIFIER_NONE);
        type_short              = make_atomic_type(ATOMIC_TYPE_SHORT,       TYPE_QUALIFIER_NONE);
        type_unsigned_short     = make_atomic_type(ATOMIC_TYPE_USHORT,      TYPE_QUALIFIER_NONE);
        type_int                = make_atomic_type(ATOMIC_TYPE_INT,         TYPE_QUALIFIER_NONE);
@@ -111,7 +116,7 @@ void init_basic_types(void)
        type_void               = make_atomic_type(ATOMIC_TYPE_VOID,        TYPE_QUALIFIER_NONE);
 
        /* microsoft types */
-       if(c_mode & _MS) {
+       if (c_mode & _MS) {
                int8_type_kind           = find_signed_int_atomic_type_kind_for_size(1);
                type_int8                = make_atomic_type(int8_type_kind, TYPE_QUALIFIER_NONE);
                int16_type_kind          = find_signed_int_atomic_type_kind_for_size(2);
@@ -144,4 +149,23 @@ void init_basic_types(void)
        /* const character types */
        type_const_char         = make_atomic_type(ATOMIC_TYPE_CHAR,        TYPE_QUALIFIER_CONST);
        type_const_char_ptr     = make_pointer_type(type_const_char,        TYPE_QUALIFIER_NONE);
+
+       /* other types */
+       type_intmax_t    = type_long_long;
+       type_size_t      = type_unsigned_long;
+       type_ssize_t     = type_long;
+       type_ptrdiff_t   = type_long;
+       type_uintmax_t   = type_unsigned_long_long;
+       type_uptrdiff_t  = type_unsigned_long;
+       type_wchar_t     = make_atomic_type(wchar_atomic_kind, TYPE_QUALIFIER_NONE);
+       type_wint_t      = type_int;
+       type_const_wchar_t
+               = make_atomic_type(wchar_atomic_kind, TYPE_QUALIFIER_CONST);
+
+       type_intmax_t_ptr  = make_pointer_type(type_intmax_t,  TYPE_QUALIFIER_NONE);
+       type_ptrdiff_t_ptr = make_pointer_type(type_ptrdiff_t, TYPE_QUALIFIER_NONE);
+       type_ssize_t_ptr   = make_pointer_type(type_ssize_t,   TYPE_QUALIFIER_NONE);
+       type_wchar_t_ptr   = make_pointer_type(type_wchar_t,   TYPE_QUALIFIER_NONE);
+       type_const_wchar_t_ptr
+               = make_pointer_type(type_const_wchar_t, TYPE_QUALIFIER_NONE);
 }