int i;
assert(typ);
#if 0
- for (i = 1; i < (ARR_LEN (irp->types)); i++) {
+ for (i = 0; i < (ARR_LEN (irp->types)); i++) {
#else
for (i = ARR_LEN (irp->types) -1; i >= 0; i--) {
#endif
memset(res, 0, sizeof(res));
irp = res;
/* res->obst = (struct obstack *) xmalloc (sizeof (struct obstack)); */
- res->graphs = NEW_ARR_F (ir_graph *, 1);
- res->types = NEW_ARR_F (type *, 1);
+ res->graphs = NEW_ARR_F (ir_graph *, 0);
+ res->types = NEW_ARR_F (type *, 0);
res->name = new_id_from_str("no_name_set");
#ifdef DEBUG_libfirm
res->max_node_nr = 0;
#endif
- res->glob_type = new_type_class(id_from_str (GLOBAL_TYPE_NAME,
+ res->glob_type = new_type_class(new_id_from_chars (GLOBAL_TYPE_NAME,
strlen(GLOBAL_TYPE_NAME)));
/* Remove type from type list. Must be treated differently than
other types. */
res->const_code_irg = new_const_code_irg();
- res->outs_state = no_outs;
+ res->outs_state = outs_none;
res->ip_outedges = NULL;
return res;
int i;
assert(irg);
free_ir_graph(irg);
- for (i = 1; i < (ARR_LEN (irp->graphs)); i++) {
+ for (i = 0; i < (ARR_LEN (irp->graphs)); i++) {
if (irp->graphs[i] == irg) {
for(; i < (ARR_LEN (irp->graphs)) - 1; i++) {
irp->graphs[i] = irp->graphs[i+1];
void set_irp_irg(int pos, ir_graph *irg) {
assert (irp && irg);
- assert (pos < (ARR_LEN((irp)->graphs) - 1));
+ assert (pos < (ARR_LEN((irp)->graphs)));
/* Strangely the first element of the array is NULL. Why?? */
- irp->graphs[pos+1] = irg;
+ irp->graphs[pos] = irg;
}
/* Adds type to the list of types in irp. */
void set_irp_type(int pos, type *typ) {
assert (irp && typ);
- assert (pos < (ARR_LEN((irp)->types) - 1));
+ assert (pos < (ARR_LEN((irp)->types)));
/* Strangely the first element of the array is NULL. Why?? */
- irp->types[pos+1] = typ;
+ irp->types[pos] = typ;
}
#ifdef DEBUG_libfirm
{
return(irp -> ip_outedges);
}
+
+
+irg_callee_info_state get_irp_callee_info_state(void) {
+ return irp->callee_info_state;
+}
+
+void set_irp_callee_info_state(irg_callee_info_state s) {
+ irp->callee_info_state = s;
+}