projects
/
cparser
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Display libfirm revision on --version
[cparser]
/
type_t.h
diff --git
a/type_t.h
b/type_t.h
index
194c1b5
..
48db72a
100644
(file)
--- a/
type_t.h
+++ b/
type_t.h
@@
-55,21
+55,14
@@
struct type_base_t {
ir_type *firm_type;
};
ir_type *firm_type;
};
+/**
+ * used for atomic types, complex and imaginary
+ */
struct atomic_type_t {
type_base_t base;
atomic_type_kind_t akind;
};
struct atomic_type_t {
type_base_t base;
atomic_type_kind_t akind;
};
-struct complex_type_t {
- type_base_t base;
- atomic_type_kind_t akind;
-};
-
-struct imaginary_type_t {
- type_base_t base;
- atomic_type_kind_t akind;
-};
-
struct pointer_type_t {
type_base_t base;
type_t *points_to;
struct pointer_type_t {
type_base_t base;
type_t *points_to;
@@
-143,8
+136,7
@@
struct compound_type_t {
};
struct enum_type_t {
};
struct enum_type_t {
- type_base_t base;
- atomic_type_kind_t akind; /**< underlying atomic type */
+ atomic_type_t base;
/** the enum entity. You can find the enum entries by walking the
* enum->base.next list until you don't find ENTITY_ENUM_VALUE entities
* anymore */
/** the enum entity. You can find the enum entries by walking the
* enum->base.next list until you don't find ENTITY_ENUM_VALUE entities
* anymore */
@@
-168,8
+160,6
@@
union type_t {
type_kind_t kind;
type_base_t base;
atomic_type_t atomic;
type_kind_t kind;
type_base_t base;
atomic_type_t atomic;
- complex_type_t complex;
- imaginary_type_t imaginary;
pointer_type_t pointer;
reference_type_t reference;
array_type_t array;
pointer_type_t pointer;
reference_type_t reference;
array_type_t array;
@@
-191,6
+181,7
@@
struct atomic_type_properties_t {
*/
unsigned struct_alignment;
unsigned flags; /**< type flags from atomic_type_flag_t */
*/
unsigned struct_alignment;
unsigned flags; /**< type flags from atomic_type_flag_t */
+ unsigned rank; /**< integer conversion rank */
};
extern atomic_type_properties_t atomic_type_properties[ATOMIC_TYPE_LAST+1];
};
extern atomic_type_properties_t atomic_type_properties[ATOMIC_TYPE_LAST+1];
@@
-210,7
+201,16
@@
type_t *make_array_type(type_t *element_type, size_t size,
type_qualifiers_t qualifiers);
function_parameter_t *allocate_parameter(type_t*);
type_qualifiers_t qualifiers);
function_parameter_t *allocate_parameter(type_t*);
+/**
+ * Duplicates a type.
+ *
+ * @param type The type to copy.
+ * @return A copy of the type.
+ *
+ * @note This does not produce a deep copy!
+ */
type_t *duplicate_type(const type_t *type);
type_t *duplicate_type(const type_t *type);
+
type_t *identify_new_type(type_t *type);
static inline bool is_typeref(const type_t *type)
type_t *identify_new_type(type_t *type);
static inline bool is_typeref(const type_t *type)
@@
-278,6
+278,14
@@
static inline bool is_type_valid(const type_t *type)
return type->kind != TYPE_ERROR;
}
return type->kind != TYPE_ERROR;
}
+/**
+ * return integer conversion rank of an atomic type kind
+ */
+static inline unsigned get_akind_rank(atomic_type_kind_t akind)
+{
+ return atomic_type_properties[akind].rank;
+}
+
/**
* Allocate a type node of given kind and initialize all
* fields with zero.
/**
* Allocate a type node of given kind and initialize all
* fields with zero.
@@
-292,7
+300,8
@@
type_t *allocate_type_zero(type_kind_t kind);
*
* @param return_type the return type
*/
*
* @param return_type the return type
*/
-type_t *make_function_0_type(type_t *return_type);
+type_t *make_function_0_type(type_t *return_type,
+ decl_modifiers_t modifiers);
/**
* Creates a return_type (func)(argument_type) function type if not
/**
* Creates a return_type (func)(argument_type) function type if not
@@
-301,7
+310,8
@@
type_t *make_function_0_type(type_t *return_type);
* @param return_type the return type
* @param argument_type the argument type
*/
* @param return_type the return type
* @param argument_type the argument type
*/
-type_t *make_function_1_type(type_t *return_type, type_t *argument_type1);
+type_t *make_function_1_type(type_t *return_type, type_t *argument_type1,
+ decl_modifiers_t modifiers);
/**
/**
@@
-309,7
+319,8
@@
type_t *make_function_1_type(type_t *return_type, type_t *argument_type1);
* if not already exists.
*/
type_t *make_function_2_type(type_t *return_type, type_t *argument_type1,
* if not already exists.
*/
type_t *make_function_2_type(type_t *return_type, type_t *argument_type1,
- type_t *argument_type2);
+ type_t *argument_type2,
+ decl_modifiers_t modifiers);
/**
* Creates a return_type (func)(argument_type, ...) function type if not
/**
* Creates a return_type (func)(argument_type, ...) function type if not
@@
-318,7
+329,9
@@
type_t *make_function_2_type(type_t *return_type, type_t *argument_type1,
* @param return_type the return type
* @param argument_type the argument type
*/
* @param return_type the return type
* @param argument_type the argument type
*/
-type_t *make_function_1_type_variadic(type_t *return_type, type_t *argument_type);
+type_t *make_function_1_type_variadic(type_t *return_type,
+ type_t *argument_type,
+ decl_modifiers_t modifiers);
/**
* Create a function type with n parameters
/**
* Create a function type with n parameters