summaryrefslogtreecommitdiff
path: root/TAO/tao/ORB_Table.cpp
diff options
context:
space:
mode:
authorOssama Othman <ossama-othman@users.noreply.github.com>2000-09-14 00:29:28 +0000
committerOssama Othman <ossama-othman@users.noreply.github.com>2000-09-14 00:29:28 +0000
commit9fd348781e6e9d32473d112d6801a8e44ccd23c3 (patch)
tree8475597a4d6722f66b2285b936eda3368ff5a9ad /TAO/tao/ORB_Table.cpp
parent69036c97699a8518fc07aa6d2c7aea815802e19a (diff)
downloadATCD-9fd348781e6e9d32473d112d6801a8e44ccd23c3.tar.gz
ChangeLogTag:Wed Sep 13 17:23:18 2000 Ossama Othman <ossama@uci.edu>
Diffstat (limited to 'TAO/tao/ORB_Table.cpp')
-rw-r--r--TAO/tao/ORB_Table.cpp151
1 files changed, 151 insertions, 0 deletions
diff --git a/TAO/tao/ORB_Table.cpp b/TAO/tao/ORB_Table.cpp
new file mode 100644
index 00000000000..e927a9336fe
--- /dev/null
+++ b/TAO/tao/ORB_Table.cpp
@@ -0,0 +1,151 @@
+// -*- C++ -*-
+//
+// $Id$
+
+#include "tao/ORB_Table.h"
+#include "tao/ORB_Core.h"
+
+#if !defined (__ACE_INLINE__)
+# include "tao/ORB_Table.inl"
+#endif /* ! __ACE_INLINE__ */
+
+ACE_RCSID(tao, ORB_Table, "$Id$")
+
+// ****************************************************************
+
+TAO_ORB_Table::TAO_ORB_Table (void)
+ : table_ (),
+ first_orb_ (0)
+{
+}
+
+TAO_ORB_Table::~TAO_ORB_Table (void)
+{
+ for (Iterator i = this->begin ();
+ i != this->end ();
+ ++i)
+ {
+ // Deallocate the ORBid.
+ CORBA::string_free (ACE_const_cast (char *, (*i).ext_id_));
+
+ // Destroy the ORB_Core
+ (*i).int_id_->_decr_refcnt ();
+ }
+ this->table_.close ();
+}
+
+TAO_ORB_Table::Iterator
+TAO_ORB_Table::begin (void)
+{
+ return this->table_.begin ();
+}
+
+TAO_ORB_Table::Iterator
+TAO_ORB_Table::end (void)
+{
+ return this->table_.end ();
+}
+
+int
+TAO_ORB_Table::bind (const char *orb_id,
+ TAO_ORB_Core *orb_core)
+{
+ // Make sure that the supplied ORB core pointer is valid,
+ // i.e. non-zero.
+ if (orb_id == 0 || orb_core == 0)
+ {
+ errno = EINVAL;
+ return -1;
+ };
+
+ const char *id = CORBA::string_dup (orb_id);
+
+ int result = this->table_.bind (id, orb_core);
+ if (result == 0)
+ {
+ // The ORB table now owns the ORB Core. As such, the reference
+ // count on the ORB Core is *not* increased.
+
+ // Only set the "first_orb_" member if the given ORB Core was
+ // successfully added to the ORB table.
+ if (this->first_orb_ == 0)
+ this->first_orb_ = orb_core;
+ }
+
+ return result;
+}
+
+TAO_ORB_Core *
+TAO_ORB_Table::find (const char *orb_id)
+{
+ TAO_ORB_Core *found = 0;
+
+ this->table_.find (orb_id, found);
+
+ return found;
+}
+
+int
+TAO_ORB_Table::unbind (const char *orb_id)
+{
+ Table::ENTRY *entry = 0;
+
+ int result = this->table_.find (orb_id, entry);
+
+ if (result == 0)
+ {
+ // Deallocate the external ID and obtain the ORB core pointer
+ // before unbinding the entry since the entry is deallocated
+ // during the call to unbind().
+ CORBA::string_free (ACE_const_cast (char *, entry->ext_id_));
+ TAO_ORB_Core *orb_core = entry->int_id_;
+
+ result = this->table_.unbind (entry);
+
+ if (result != 0)
+ return result;
+
+ if (orb_core == this->first_orb_)
+ {
+ Iterator begin = this->begin ();
+ Iterator end = this->end ();
+ if (begin != end)
+ this->first_orb_ = (*begin).int_id_;
+ else
+ this->first_orb_ = 0;
+ }
+
+ orb_core->_decr_refcnt ();
+ }
+
+ return result;
+}
+
+
+#if defined (ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION)
+
+template class TAO_Singleton<TAO_ORB_Table,ACE_SYNCH_MUTEX>;
+
+template class ACE_Hash_Map_Entry<const char *, TAO_ORB_Core *>;
+template class ACE_Hash_Map_Manager<const char *, TAO_ORB_Core *, ACE_Null_Mutex>;
+template class ACE_Hash_Map_Iterator<const char *, TAO_ORB_Core *, ACE_Null_Mutex>;
+template class ACE_Hash_Map_Reverse_Iterator<const char *, TAO_ORB_Core *, ACE_Null_Mutex>;
+template class ACE_Hash_Map_Manager_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>;
+template class ACE_Hash_Map_Iterator_Base_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>;
+template class ACE_Hash_Map_Iterator_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>;
+template class ACE_Hash_Map_Reverse_Iterator_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>;
+
+#elif defined (ACE_HAS_TEMPLATE_INSTANTIATION_PRAGMA)
+
+#pragma instantiate TAO_Singleton<TAO_ORB_Table,ACE_SYNCH_MUTEX>
+
+#pragma instantiate ACE_Hash_Map_Entry<const char *, TAO_ORB_Core *>
+#pragma instantiate ACE_Hash_Map_Manager<const char *, TAO_ORB_Core *, ACE_Null_Mutex>
+#pragma instantiate ACE_Hash_Map_Iterator<const char *, TAO_ORB_Core *, ACE_Null_Mutex>
+#pragma instantiate ACE_Hash_Map_Reverse_Iterator<const char *, TAO_ORB_Core *, ACE_Null_Mutex>
+#pragma instantiate ACE_Hash_Map_Manager_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>
+#pragma instantiate ACE_Hash_Map_Iterator_Base_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>
+#pragma instantiate ACE_Hash_Map_Iterator_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>
+#pragma instantiate ACE_Hash_Map_Reverse_Iterator_Ex<const char *, TAO_ORB_Core *, ACE_Hash<const char *>, ACE_Equal_To<const char *>, ACE_Null_Mutex>
+
+#endif /* ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION */