3 //=============================================================================
7 * A prototype mechanism that allow all ACE objects to be registered
8 * with a central in-memory "database" that can dump the state of all
9 * live ACE objects (e.g., from within a debugger).
11 * The macros which allow easy registration and removal of objects to be
12 * dumped (ACE_REGISTER_OBJECT and ACE_REMOVE_OBJECT) are turned into
13 * no-ops by compiling with the ACE_NDEBUG macro defined. This allows
14 * usage to be removed in "release mode" builds without changing code.
16 * There are several interesting aspects to this design:
18 * 1. It uses the External Polymorphism pattern to avoid having to
19 * derive all ACE classes from a common base class that has virtual
20 * methods (this is crucial to avoid unnecessary overhead). In
21 * addition, there is no additional space added to ACE objects
22 * (this is crucial to maintain binary layout compatibility).
24 * 2. This mechanism can be conditionally compiled in order to
25 * completely disable this feature entirely. Moreover, by
26 * using macros there are relatively few changes to ACE code.
28 * 3. This mechanism copes with single-inheritance hierarchies of
29 * dumpable classes. In such cases we typically want only one
30 * dump, corresponding to the most derived instance. Thanks to
31 * Christian Millour (chris@etca.fr) for illustrating how to do
32 * this. Note, however, that this scheme doesn't generalize to
33 * work with multiple-inheritance or virtual base classes.
35 * Future work includes:
37 * 1. Using a dynamic object table rather than a static table
39 * 2. Adding support to allow particular classes of objects to
40 * be selectively dumped.
42 * @author Doug Schmidt
44 //=============================================================================
49 #include /**/ "ace/pre.h"
51 #include /**/ "ace/ACE_export.h"
53 #if !defined (ACE_LACKS_PRAGMA_ONCE)
55 #endif /* ACE_LACKS_PRAGMA_ONCE */
57 ACE_BEGIN_VERSIONED_NAMESPACE_DECL
62 * @brief Base class that defines a uniform interface for all object
65 class ACE_Export ACE_Dumpable
69 friend class ACE_Dumpable_Ptr
;
72 ACE_Dumpable (const void *);
74 /// This pure virtual method must be filled in by a subclass.
75 virtual void dump () const = 0;
78 virtual ~ACE_Dumpable ();
81 /// Pointer to the object that is being stored.
86 * @class ACE_Dumpable_Ptr
88 * @brief A smart pointer stored in the in-memory object database
89 * ACE_ODB. The pointee (if any) is deleted when reassigned.
91 class ACE_Export ACE_Dumpable_Ptr
94 ACE_Dumpable_Ptr (const ACE_Dumpable
*dumper
= 0);
95 const ACE_Dumpable
*operator->() const;
96 void operator= (const ACE_Dumpable
*dumper
) const;
99 /// "Real" pointer to the underlying abstract base class
100 /// pointer that does the real work.
101 const ACE_Dumpable
*dumper_
;
107 * @brief This is the object database (ODB) that keeps track of all
110 class ACE_Export ACE_ODB
113 /// @todo This is clearly inadequate and should be dynamic...
114 enum {MAX_TABLE_SIZE
= 100000};
116 /// Iterates through the entire set of registered objects and
117 /// dumps their state.
118 void dump_objects ();
120 /// Add the tuple <dumper, this_> to the list of registered ACE objects.
121 void register_object (const ACE_Dumpable
*dumper
);
123 /// Use <this_> to locate and remove the associated <dumper> from the
124 /// list of registered ACE objects.
125 void remove_object (const void *this_
);
127 /// Interface to the Singleton instance of the object database.
128 static ACE_ODB
*instance ();
130 ACE_ALLOC_HOOK_DECLARE
;
133 ACE_ODB (); // Ensure we have a Singleton...
137 /// Pointer to the object that is registered.
140 /// Smart pointer to the ACE_Dumpable object associated with this_.
141 /// This uses an ACE_Dumpable_Ptr, instead of a bare pointer, to
142 /// cope with hierarchies of dumpable classes. In such cases we
143 /// typically want only one dump, corresponding to the most derived
144 /// instance. To achieve this, the handle registered for the
145 /// subobject corresponding to the base class is destroyed (hence
146 /// on destruction of the subobject its handle won't exist anymore
147 /// and we'll have to check for that).
148 const ACE_Dumpable_Ptr dumper_
;
150 Tuple () : this_ (0), dumper_(0) {}
153 /// Singleton instance of this class.
154 static ACE_ODB
*instance_
;
156 /// The current implementation is very simple-minded and will be
157 /// changed to be dynamic.
158 Tuple object_table_
[ACE_ODB::MAX_TABLE_SIZE
];
160 /// Current size of <object_table_>.
164 ACE_END_VERSIONED_NAMESPACE_DECL
166 // Include the templates classes at this point.
167 #include "ace/Dump_T.h"
169 #include /**/ "ace/post.h"
170 #endif /* ACE_DUMP_H */