some fixes for xml dumper / still buggy.
[libfirm] / ir / debug / dbginfo.c
index 1f1ebef..998e0b1 100644 (file)
@@ -1,14 +1,14 @@
 /*
-**  Copyright (C) 2001 by Universitaet Karlsruhe
-**  All rights reserved.
-**
-**  Authors: Goetz Lindenmaier
-**
-**  dbginfo: This is a empty implementation of the Firm interface to
-**  debugging support.  It only guarantees that the Firm library compiles
-**  and runs without any real debugging support.
-**  The functions herein are declared weak so that they can be overriden
-**  by a real implementation.
+*  Copyright (C) 2001 by Universitaet Karlsruhe
+*  All rights reserved.
+*
+*  Authors: Goetz Lindenmaier
+*
+*  dbginfo: This is a empty implementation of the Firm interface to
+*  debugging support.  It only guarantees that the Firm library compiles
+*  and runs without any real debugging support.
+*  The functions herein are declared weak so that they can be overriden
+*  by a real implementation.
 */
 
 /* $Id$ */
 # include <config.h>
 #endif
 
-#include "dbginfo.h"
+#include "dbginfo_t.h"
 #include "irnode_t.h"
+#include "type_t.h"
+#include "entity_t.h"
 
-inline void
+
+INLINE void
+dbg_info_merge_pair(ir_node *nw, ir_node *old, dbg_action info) {
+  set_irn_dbg_info(nw, get_irn_dbg_info(old));
+}
+
+INLINE void
+dbg_info_merge_sets(ir_node **new_nodes, int n_new_nodes,
+                   ir_node **old_nodes, int n_old_nodes,
+                   dbg_action info) {
+}
+
+
+void (*__dbg_info_merge_pair)(ir_node *nw, ir_node *old, dbg_action info)
+     = &dbg_info_merge_pair;
+
+void (*__dbg_info_merge_sets)(ir_node **new_nodes, int n_new_nodes,
+                             ir_node **old_nodes, int n_old_nodes,
+                             dbg_action info)
+     = &dbg_info_merge_sets;
+
+
+void dbg_init( merge_pair_func *mpf, merge_sets_func *msf )
+{
+  __dbg_info_merge_pair = mpf;
+  __dbg_info_merge_sets = msf;
+}
+
+
+INLINE void
 set_irn_dbg_info(ir_node *n, struct dbg_info* db) {
   n->dbi = db;
 }
 
-inline struct dbg_info *
+INLINE struct dbg_info *
 get_irn_dbg_info(ir_node *n) {
   return n->dbi;
 }
 
-inline void
-dbg_info_copy(ir_node *nw, ir_node *old, ident *info) {
-  set_irn_dbg_info(new, get_irn_dbg_info(old));
-}
 
-inline void
-dbg_info_merge(ir_node **new_nodes, ir_node **old_nodes, ident *info) {
+/* Routines to access the field of an entity containing the
+   debugging information. */
+INLINE void set_entity_dbg_info(entity *ent, dbg_info* db) {
+  ent->dbi = db;
+}
+INLINE dbg_info *get_entity_dbg_info(entity *ent) {
+  return ent->dbi;
+}
+/* Routines to access the field of a type containing the
+   debugging information. */
+INLINE void set_type_dbg_info(type *tp, dbg_info* db) {
+  tp->dbi = db;
+}
+INLINE dbg_info *get_type_dbg_info(type *tp) {
+  return tp->dbi;
 }