diff options
Diffstat (limited to 'ACE/TAO/orbsvcs/DevGuideExamples/NamingService/corbaname_Messenger/MessengerServer.cpp')
-rw-r--r-- | ACE/TAO/orbsvcs/DevGuideExamples/NamingService/corbaname_Messenger/MessengerServer.cpp | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/ACE/TAO/orbsvcs/DevGuideExamples/NamingService/corbaname_Messenger/MessengerServer.cpp b/ACE/TAO/orbsvcs/DevGuideExamples/NamingService/corbaname_Messenger/MessengerServer.cpp new file mode 100644 index 00000000000..cbea180cda8 --- /dev/null +++ b/ACE/TAO/orbsvcs/DevGuideExamples/NamingService/corbaname_Messenger/MessengerServer.cpp @@ -0,0 +1,102 @@ +// $Id$ + +#include "Messenger_i.h" +#include "orbsvcs/CosNamingC.h" +#include <iostream> +#include <fstream> +#include "ace/Get_Opt.h" + +const ACE_TCHAR *output_file = ACE_TEXT ("MessengerServer.ready"); + +int +parse_args (int argc, ACE_TCHAR *argv[]) +{ + ACE_Get_Opt get_opts (argc, argv, ACE_TEXT("o:")); + int c; + + while ((c = get_opts ()) != -1) + switch (c) + { + case 'o': + output_file = get_opts.opt_arg (); + break; + + case '?': + default: + ACE_ERROR_RETURN ((LM_ERROR, + "usage: %s " + "-o <outputfile>" + "\n", + argv [0]), + -1); + } + // Indicates sucessful parsing of the command line + return 0; +} + +int ACE_TMAIN (int argc, ACE_TCHAR *argv[]) +{ + try { + // Initialize orb + CORBA::ORB_var orb = CORBA::ORB_init( argc, argv ); + + if (parse_args (argc, argv) != 0) + return 1; + + //Get reference to Root POA + CORBA::Object_var obj = orb->resolve_initial_references( "RootPOA" ); + PortableServer::POA_var poa = PortableServer::POA::_narrow( obj.in() ); + + // Activate POA Manager + PortableServer::POAManager_var mgr = poa->the_POAManager(); + mgr->activate(); + + // Find the Naming Service + obj = orb->resolve_initial_references("NameService"); + CosNaming::NamingContext_var root = + CosNaming::NamingContext::_narrow(obj.in()); + if (CORBA::is_nil(root.in())) { + std::cerr << "Nil Naming Context reference" << std::endl; + return 1; + } + + // Bind the example Naming Context, if necessary + CosNaming::Name name; + name.length( 1 ); + name[0].id = CORBA::string_dup("example"); + try { + CORBA::Object_var dummy = root->resolve(name); + } + catch(const CosNaming::NamingContext::NotFound&) { + CosNaming::NamingContext_var dummy = root->bind_new_context( name ); + } + + // Bind the Messenger object + name.length( 2 ); + name[1].id = CORBA::string_dup("Messenger"); + + // Create an object + PortableServer::Servant_var<Messenger_i> servant = new Messenger_i; + PortableServer::ObjectId_var oid = poa->activate_object(servant.in()); + obj = poa->id_to_reference(oid.in()); + Messenger_var messenger = Messenger::_narrow(obj.in()); + root->rebind(name, messenger.in()); + + std::cout << "Messenger object bound in Naming Service" << std::endl; + + // Write a file to let the run_test.pl script know we are ready. + std::ofstream iorFile( ACE_TEXT_ALWAYS_CHAR(output_file) ); + iorFile << "Ready" << std::endl; + iorFile.close(); + + // Accept requests + orb->run(); + orb->destroy(); + } + catch(const CORBA::Exception& ex) { + std::cerr << "server:Caught a CORBA::Exception: " << ex << std::endl; + return 1; + } + + return 0; +} |