X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Ftr%2Ftpop_t.h;h=7cc1fc0163f2352c7c67d0cc19f931cb68e1b53d;hb=199ea1a4479a4d8dcbebfde81820286935e64b0c;hp=57498ca0f434cd0ddaf40ba7ae508a9a87559d28;hpb=8ca297d3fa1c84b58d71a9ec102061239159f9a7;p=libfirm diff --git a/ir/tr/tpop_t.h b/ir/tr/tpop_t.h index 57498ca0f..7cc1fc016 100644 --- a/ir/tr/tpop_t.h +++ b/ir/tr/tpop_t.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 1995-2007 University of Karlsruhe. All right reserved. + * Copyright (C) 1995-2011 University of Karlsruhe. All right reserved. * * This file is part of libFirm. * @@ -21,7 +21,6 @@ * @file * @brief Opcode of types -- private header. * @author Goetz Lindenmaier, Michael Beck - * @version $Id$ */ #ifndef FIRM_TR_TPOP_T_H #define FIRM_TR_TPOP_T_H @@ -29,17 +28,11 @@ #include #include "firm_types.h" -#include "tpop.h" +#include "typerep.h" #include "irmode.h" -/** - * @file tpop_t.h - * - * This file contains the datatypes hidden in tpop.h. - * - * @author Goetz Lindenmaier - * @see tpop.h - */ +#define get_tpop_code(op) _get_tpop_code(op) +#define get_tpop_ident(op) _get_tpop_ident(op) /** A function called to free attributes of a type. */ typedef void (*free_attrs_func)(ir_type *tp); @@ -53,16 +46,16 @@ typedef void (*free_auto_entities_func)(ir_type *tp); /** A function called to set the mode of a type. */ typedef void (*set_type_mode_func)(ir_type *tp, ir_mode *m); -/** A function called to set the size of a type in bits */ -typedef void (*set_type_size_func)(ir_type *tp, int size); +/** A function called to set the size of a type in bytes. */ +typedef void (*set_type_size_func)(ir_type *tp, unsigned size); /** A function called to get the number of compound members */ -typedef int (*get_n_members_func)(const ir_type *tp); +typedef size_t (*get_n_members_func)(const ir_type *tp); /** A function called to get the pos'th compound member */ -typedef ir_entity *(*get_member_func)(const ir_type *tp, int pos); +typedef ir_entity *(*get_member_func)(const ir_type *tp, size_t pos); -typedef int (*get_member_index_func)(const ir_type *tp, ir_entity *member); +typedef size_t (*get_member_index_func)(const ir_type *tp, ir_entity *member); /** A function called to insert an entity into the type */ typedef void (*insert_entity_func)(ir_type *tp, ir_entity *member); @@ -70,15 +63,15 @@ typedef void (*insert_entity_func)(ir_type *tp, ir_entity *member); /** * tp_op operations. */ -typedef struct _tp_op_ops { - free_attrs_func free_attrs; /**< called to free the attributes of a type */ - free_entities_func free_entities; /**< called to free the owned entities of a type */ - free_auto_entities_func free_auto_entities; /**< called to free the automatic allocated entities of a type */ - set_type_mode_func set_type_mode; /**< called to set a ir_mode of a type */ - set_type_size_func set_type_size; /**< called to set the bit size of a type */ - get_n_members_func get_n_members; /**< called to return the number of compound members */ - get_member_func get_member; /**< called to get the pos'th compound member */ - get_member_index_func get_member_index; /**< called to get the index of a compound member */ +typedef struct tp_op_ops { + free_attrs_func free_attrs; /**< Called to free the attributes of a type. */ + free_entities_func free_entities; /**< Called to free the owned entities of a type. */ + free_auto_entities_func free_auto_entities; /**< Called to free the automatic allocated entities of a type. */ + set_type_mode_func set_type_mode; /**< Called to set a ir_mode of a type. */ + set_type_size_func set_type_size; /**< Called to set the byte size of a type. */ + get_n_members_func get_n_members; /**< Called to return the number of compound members. */ + get_member_func get_member; /**< Called to get the pos'th compound member. */ + get_member_index_func get_member_index; /**< Called to get the index of a compound member. */ } tp_op_ops; /** possible flags for a type opcode */ @@ -86,19 +79,19 @@ enum tp_op_flags_t { TP_OP_FLAG_COMPOUND = 1 /**< is a compound type */ }; -/** The type opcode */ +/** The type opcode. */ struct tp_op { - tp_opcode code; /**< the tpop code */ - ident *name; /**< the name of the type opcode */ - size_t attr_size; /**< the attribute size for a type of this opcode */ - unsigned flags; /**< flags for this opcode */ - tp_op_ops ops; /**< tp_op operations */ + tp_opcode code; /**< The tpop code. */ + ident *name; /**< The name of the type opcode. */ + size_t attr_size; /**< The attribute size for a type of this opcode. */ + unsigned flags; /**< Flags for this opcode. */ + tp_op_ops ops; /**< tp_op operations. */ }; /** * Returns a new type opcode. * - * Allocates a new tp_op struct and initializes it's fields with + * Allocates a new tp_op struct and initializes its fields with * the passed values. This function is only to be used during * initialization of the library. * @@ -110,13 +103,12 @@ struct tp_op { * @param ops the tp_op operations for this type * @return A new type opcode. */ -tp_op *new_tpop (tp_opcode code, ident *name, unsigned flags, size_t attr_size, - const tp_op_ops *ops); +const tp_op *new_tpop (tp_opcode code, ident *name, unsigned flags, size_t attr_size, const tp_op_ops *ops); /** - * Free a tpop datastructure. + * Free a tpop data structure. */ -void free_tpop(tp_op *tpop); +void free_tpop(const tp_op *tpop); /** * Initialize the tpop module. @@ -127,7 +119,7 @@ void free_tpop(tp_op *tpop); * Allocates opcodes for classes, struct, method, union, array, * enumeration, pointer and primitive and sets the according values. */ -void init_tpop (void); +void init_tpop(void); /** * Finalize the tpop module. @@ -145,30 +137,23 @@ void finish_tpop(void); * @param op The type opcode to get the size for. * @return The size of the attribute of types with this opcode. */ -int get_tpop_attr_size (const tp_op *op); - +static inline size_t get_tpop_attr_size(const tp_op *op) +{ + return op->attr_size; +} /* ---------------- * * inline functions * * -----------------*/ -static INLINE tp_opcode -_get_tpop_code(const tp_op *op) { +static inline tp_opcode _get_tpop_code(const tp_op *op) +{ return op->code; } -static INLINE ident * -_get_tpop_ident(const tp_op *op){ +static inline ident *_get_tpop_ident(const tp_op *op) +{ return op->name; } -static INLINE size_t -_get_tpop_attr_size(const tp_op *op) { - return op->attr_size; -} - -#define get_tpop_code(op) _get_tpop_code(op) -#define get_tpop_ident(op) _get_tpop_ident(op) -#define get_tpop_attr_size(op) _get_tpop_attr_size(op) - #endif /* FIRM_TR_TPOP_T_H */