cosmetic changes
[libfirm] / ir / common / firm_common.c
1 /*
2  * Project:     libFIRM
3  * File name:   ir/common/firm_common.c
4  * Purpose:
5  * Author:      Martin Trapp, Christian Schaefer
6  * Modified by: Goetz Lindenmaier, Michael Beck
7  * Created:
8  * CVS-ID:      $Id$
9  * Copyright:   (c) 1998-2006 Universität Karlsruhe
10  * Licence:     This file protected by GPL -  GNU GENERAL PUBLIC LICENSE.
11  */
12 #ifdef HAVE_CONFIG_H
13 # include "config.h"
14 #endif
15
16 #include "firm_common_t.h"
17 #include "irgraph.h"
18 #include "irloop.h"
19 #include "tv.h"
20
21 /**
22  * Ideally, this macro would check if size bytes could be read at
23  * pointer p. No generic solution.
24  */
25 #define POINTER_READ(p, size) (p)
26
27 /* returns the kind of the thing */
28 firm_kind get_kind(const void *firm_thing) {
29   return POINTER_READ(firm_thing, sizeof(firm_kind)) ? *(firm_kind *)firm_thing : k_BAD;
30 }  /* get_kind */
31
32 const char *print_firm_kind(void *firm_thing) {
33   if (! firm_thing)
34     return "(NULL)";
35
36   switch (*(firm_kind *)firm_thing) {
37   case k_entity                 : return "k_entity";
38   case k_type                   : return "k_type";
39   case k_ir_graph               : return "k_ir_graph";
40   case k_ir_node                : return "k_ir_node";
41   case k_ir_mode                : return "k_ir_mode";
42   case k_ir_op                  : return "k_ir_op";
43   case k_tarval                 : return "k_tarval";
44   case k_ir_loop                : return "k_ir_loop";
45   case k_ir_compound_graph_path : return "k_ir_compound_graph_path";
46   case k_ir_extblk              : return "k_ir_extblk";
47   case k_ir_prog                : return "k_ir_prog";
48   default: return "";
49   }
50 }  /* print_firm_kind */
51
52 /*
53  * identify a firm thing
54  */
55 void firm_identify_thing(void *X)
56 {
57   if (! X) {
58     printf("(NULL)\n");
59     return;
60   }
61
62   switch (get_kind(X)) {
63   case k_BAD:
64     printf("BAD: (%p)\n", X);
65     break;
66   case k_entity:
67     printf("entity: %s: %ld (%p)\n", get_entity_name(X), get_entity_nr(X), X);
68     break;
69   case k_type:
70     printf("type: %s %s: %ld (%p)\n", get_type_tpop_name(X), get_type_name(X), get_type_nr(X), X);
71     break;
72   case k_ir_graph:
73     printf("graph: %s: %ld (%p)\n", get_entity_name(get_irg_entity(X)), get_irg_graph_nr(X), X);
74     break;
75   case k_ir_node:
76     printf("irnode: %s%s %ld (%p)\n", get_irn_opname(X), get_mode_name(get_irn_mode(X)), get_irn_node_nr(X), X);
77     break;
78   case k_ir_mode:
79     printf("mode %s: (%p)\n", get_mode_name(X), X);
80     break;
81   case k_ir_op:
82     printf("op %s: (%p)\n", get_op_name(X), X);
83     break;
84   case k_tarval:
85     printf("tarval : "); tarval_printf(X); printf(" (%p)\n", X);
86     break;
87   case k_ir_loop:
88     printf("loop: with depth %d: (%p)\n", get_loop_depth(X), X);
89     break;
90   case k_ir_compound_graph_path:
91     printf("compound_graph_path: (%p)\n", X);
92     break;
93   case k_ir_extblk:
94     printf("extended block: (%p)\n", X);
95     break;
96   case k_ir_prog:
97     printf("irp: (%p)\n", X);
98     break;
99   default:
100     printf("Cannot identify thing at (%p).\n", X);
101   }
102 }  /* firm_identify_thing */