Revert "Use a variable on the stack to not have a temporary in the call"
[ACE_TAO.git] / TAO / tao / ObjectKey_Table.h
blob2928beea0e4064a3b48fb87ea4735054522ff58b
1 // -*- C++ -*-
3 //=============================================================================
4 /**
5 * @file ObjectKey_Table.h
7 * @author Balachandran Natarajan <bala@dre.vanderbilt.edu>
8 */
9 //=============================================================================
11 #ifndef TAO_OBJECTKEY_TABLE_H
12 #define TAO_OBJECTKEY_TABLE_H
14 #include /**/ "ace/pre.h"
15 #include "ace/RB_Tree.h"
17 #if !defined (ACE_LACKS_PRAGMA_ONCE)
18 # pragma once
19 #endif /* ACE_LACKS_PRAGMA_ONCE */
21 #include "ace/Null_Mutex.h"
23 #include "tao/Object_KeyC.h"
24 #include /**/ "tao/Versioned_Namespace.h"
26 TAO_BEGIN_VERSIONED_NAMESPACE_DECL
28 // Forward declarations
29 class TAO_ORB_Core;
31 namespace TAO
33 // Forward declarations within the namespace..
34 class Refcounted_ObjectKey;
35 class ObjectKey;
37 /**
38 * @class Less_Than_ObjectKey
40 * @brief Compares the length and then the contents of ObjectKeys.
42 * Should have been a specialization of the functor
43 * ACE_Less_Than<sequence<CORBA::Octet>>. But that will not work
44 * so easily across bunch of stuff. Hence let us put up with this
45 * for the time being.
47 class TAO_Export Less_Than_ObjectKey
49 public:
50 bool operator () (const TAO::ObjectKey &lhs,
51 const TAO::ObjectKey &rhs) const;
54 /**
55 * @class ObjectKey_Table
57 * @brief Table that maintains the set of ObjectKey's seen by the
58 * ORB.
60 * The ORB maintains one table for the whole ORB. ObjectKeys
61 * generated by the ORB or the ones seen by the ORB from remote
62 * ORB's are stored here. The ObjectKeys are stored through a
63 * wrapper which encapsulates the reference count on them. This class
64 * actually provides the synchronization mechanism for manipulating
65 * the reference counts on the object keys provided by the wrapper
66 * class.
68 * This class does not offer a find () call with a reason. The call
69 * to bind () will return a pointer which is expected to be cached
70 * by the client/caller and use the pointer in every invocation.
72 * @note This class uses the ACE_RB_Tree to maintain the table of
73 * ObjectKeys. The RB_Tree has good insertion and lookup
74 * properties. Its Iteration properties are not that good, but we
75 * don't need to do much iteration unless we are closing down the
76 * table.
78 * @note The reasons to use RB_Tree are its good dynamic
79 * properties. We should try to strategize the class to use either a
80 * Hash_Map or a RB_Tree based on some runtime option. For that we
81 * need an adapter class in ACE, like an ACE_Lock_Adapter class. We
82 * will do that if our instrumentation shows the need for it.
85 class TAO_Export ObjectKey_Table
87 public:
88 /// Default Constructor and destructor..
89 ObjectKey_Table ();
91 ~ObjectKey_Table ();
93 /// Iterates and unbinds the contents of the table.
94 int destroy ();
96 /// Bind the ObjectKey in the table.
97 /**
98 * Bind an ObjectKey in the table and return a pointer to the
99 * Refcounted_ObjectKey which the client can use. If the ObjectKey
100 * is already available in the table, this operation just
101 * increments the refcount on the ObjectKey. If the ObjectKey is
102 * new it is bounded to the table. Returns a 0 on success and a -1
103 * on failure.
105 int bind (const ObjectKey &key, Refcounted_ObjectKey *&key_new);
107 /// Unbind an ObjectKey from the table.
108 int unbind (TAO::Refcounted_ObjectKey *&key);
110 protected:
111 /// Implementation for bind ().
112 int bind_i (const ObjectKey &key, Refcounted_ObjectKey *&key_new);
114 /// Implementation for unbind ().
115 int unbind_i (Refcounted_ObjectKey *&key);
117 private:
118 ObjectKey_Table (const ObjectKey_Table &) = delete;
119 ObjectKey_Table &operator= (const ObjectKey_Table &) = delete;
121 /// Some useful typedefs.
122 typedef ACE_RB_Tree<TAO::ObjectKey,
123 TAO::Refcounted_ObjectKey *,
124 TAO::Less_Than_ObjectKey,
125 ACE_Null_Mutex> TABLE;
127 /// Lock for the table.
128 TAO_SYNCH_MUTEX lock_;
130 /// Table that contains the data
131 TABLE table_;
135 TAO_END_VERSIONED_NAMESPACE_DECL
137 #if defined (__ACE_INLINE__)
138 # include "tao/ObjectKey_Table.inl"
139 #endif /* __ACE_INLINE__ */
141 #include /**/ "ace/post.h"
143 #endif /*TAO_OBJECT_KEY_TABLE_H*/