some testcases I had lying around here
[cparser] / type_t.h
index d6cbaa6..becc8a0 100644 (file)
--- a/type_t.h
+++ b/type_t.h
@@ -33,7 +33,7 @@
 
 extern struct obstack *type_obst;
 
-typedef enum {
+typedef enum type_kind_t {
        TYPE_INVALID,
        TYPE_ERROR,
        TYPE_ATOMIC,
@@ -51,7 +51,7 @@ typedef enum {
        TYPE_TYPEOF,
 } type_kind_t;
 
-typedef enum {
+typedef enum type_modifier_t {
        TYPE_MODIFIER_NONE              = 0,
        TYPE_MODIFIER_TRANSPARENT_UNION = 1 << 0,
 } type_modifier_t;
@@ -59,10 +59,11 @@ typedef unsigned short type_modifiers_t;
 
 struct type_base_t {
        type_kind_t       kind;
+       source_position_t source_position;
+       il_size_t         size;           /**< The size of this type. */
        type_qualifiers_t qualifiers;
        type_modifiers_t  modifiers;
-       unsigned char     alignment;      /**< The extra alignment of the type, 0 for default. */
-       source_position_t source_position;
+       il_alignment_t    alignment;      /**< The extra alignment of the type, 0 for default. */
 
        ir_type          *firm_type;
 };
@@ -117,8 +118,8 @@ struct function_parameter_t {
 };
 
 /** Calling conventions. */
-typedef enum {
-       CC_DEFAULT,      /**< defualt calling convention. */
+typedef enum cc_kind_t {
+       CC_DEFAULT,      /**< default calling convention. */
        CC_CDECL,        /**< cdecl calling convention. */
        CC_STDCALL,      /**< stdcall calling convention. */
        CC_FASTCALL,     /**< fastcall calling convention. */
@@ -131,7 +132,7 @@ typedef enum {
 struct function_type_t {
        type_base_t           base;
        type_t               *return_type;        /**< The return type. */
-       function_parameter_t *parameters;         /**< A linst of the parameter types. */
+       function_parameter_t *parameters;         /**< A list of the parameter types. */
        cc_kind_t             calling_convention; /**< The specified calling convention. */
        unsigned              variadic : 1;
        unsigned              unspecified_parameters : 1;
@@ -140,6 +141,7 @@ struct function_type_t {
 
 struct compound_type_t {
        type_base_t    base;
+       unsigned       packed:1;       /** Set if packed was specified. */
        /** the declaration of the compound type, the scope of the declaration
         *  contains the compound entries. */
        declaration_t *declaration;
@@ -169,7 +171,8 @@ struct typeof_type_t {
 struct bitfield_type_t {
        type_base_t   base;
        type_t       *base_type;
-       expression_t *size;
+       expression_t *size_expression; /**< The expression for the bit size. */
+       il_size_t     bit_size;        /**< Size of this bitfield in bits. */
 };
 
 union type_t {
@@ -259,6 +262,7 @@ static inline bool is_type_compound(const type_t *type)
 
 static inline bool is_type_valid(const type_t *type)
 {
+       assert(!is_typeref(type));
        return type->kind != TYPE_ERROR;
 }