Dumping pointers differently
[libfirm] / testprograms / memory_example.c
index 9a70fac..9b76b11 100644 (file)
@@ -53,10 +53,11 @@ int
 main(void)
 {
   ir_graph *irg;
-  type_class *owner;
-  type_method *method;    /* the type of this method */
-  entity *ent;
-  ir_node *a, *b, *x, *y, *r;
+  type     *owner;
+  type     *method;    /* the type of this method */
+  type     *prim_t_int;
+  entity   *ent;
+  ir_node  *a, *b, *x, *y, *r;
 
   printf("\nCreating an IR graph: MEMORY_EXAMPLE...\n");
 
@@ -64,10 +65,14 @@ main(void)
 
   set_opt_dead_node_elimination (1);
 
+  /*** Make basic type information for primitive type int. ***/
+  prim_t_int = new_type_primitive(id_from_str ("int", 3), mode_I);
+
   /* a class to get started with, containing the main procedure */
   owner = new_type_class (id_from_str ("MEMORY_EXAMPLE", 14));
-  method = new_type_method (id_from_str("main", 4), 0, 2);
-  ent = new_entity ((type *)owner, id_from_str ("main", 4), (type *)method);
+  method = new_type_method (id_from_str("main", 4), 0, 1);
+  set_method_res_type(method, 0, prim_t_int);
+  ent = new_entity (owner, id_from_str ("main", 4), method);
 
   /* Generates start and end blocks and nodes and a first, initial block */
   irg = new_ir_graph (ent, 4);
@@ -136,6 +141,8 @@ main(void)
   add_in_edge (get_irg_end_block(irg), x);
   mature_block (get_irg_end_block(irg));
 
+  finalize_cons (irg);
+
   printf("Optimizing ...\n");
   dead_node_elimination(irg);