summaryrefslogtreecommitdiff
path: root/ACE/TAO/orbsvcs/orbsvcs/Naming/Naming_Client.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/TAO/orbsvcs/orbsvcs/Naming/Naming_Client.cpp')
-rw-r--r--ACE/TAO/orbsvcs/orbsvcs/Naming/Naming_Client.cpp60
1 files changed, 60 insertions, 0 deletions
diff --git a/ACE/TAO/orbsvcs/orbsvcs/Naming/Naming_Client.cpp b/ACE/TAO/orbsvcs/orbsvcs/Naming/Naming_Client.cpp
new file mode 100644
index 00000000000..ee5a710de0d
--- /dev/null
+++ b/ACE/TAO/orbsvcs/orbsvcs/Naming/Naming_Client.cpp
@@ -0,0 +1,60 @@
+// $Id$
+
+#include "orbsvcs/Naming/Naming_Client.h"
+#include "orbsvcs/CosNamingC.h"
+#include "ace/Log_Msg.h"
+
+ACE_RCSID (Naming,
+ Naming_Client,
+ "$Id$")
+
+TAO_BEGIN_VERSIONED_NAMESPACE_DECL
+
+CosNaming::NamingContext_ptr
+TAO_Naming_Client::operator -> (void) const
+{
+ return this->naming_context_.ptr ();
+}
+
+CosNaming::NamingContext_ptr
+TAO_Naming_Client::get_context (void) const
+{
+ // Must duplicate this pointer so it can be stored in a _var.
+ return CosNaming::NamingContext::_duplicate (this->naming_context_.in ());
+}
+
+int
+TAO_Naming_Client::init (CORBA::ORB_ptr orb, ACE_Time_Value *timeout)
+{
+ try
+ {
+ CORBA::Object_var naming_obj =
+ orb->resolve_initial_references ("NameService", timeout);
+
+ if (CORBA::is_nil (naming_obj.in ()))
+ ACE_ERROR_RETURN ((LM_ERROR,
+ " (%P|%t) Unable to initialize the NameService.\n"),
+ -1);
+ this->naming_context_ =
+ CosNaming::NamingContext::_narrow (naming_obj.in ());
+ }
+ catch (const CORBA::Exception& ex)
+ {
+ ex._tao_print_exception ("TAO_Naming_Client::init");
+ return -1;
+ }
+
+ return 0;
+}
+
+TAO_Naming_Client::TAO_Naming_Client (void)
+{
+ // Do nothing
+}
+
+TAO_Naming_Client::~TAO_Naming_Client (void)
+{
+ // Do nothing
+}
+
+TAO_END_VERSIONED_NAMESPACE_DECL