int main(int argc, char **argv) { // Removes ORB related arguments CORBA::ORB_var orb = CORBA::ORB_init(argc, argv); // Program options std::string register_servant; std::string proxy_reference; _po::options_description _desc("Proxy Server options"); _desc.add_options() ("help,h", "produce help message") ("register-servant,r", _po::value< std::string >(®ister_servant), "register the servant into the name service") ("proxy-reference,p", _po::value< std::string >(&proxy_reference), "forward received calls to another servant"); _po::variables_map _vm; _po::store(_po::parse_command_line(argc, argv, _desc), _vm); _po::notify(_vm); if (_vm.count("help")) { std::cout << _desc << std::endl; return 0; } bool reference_is_ns_entry = false; // TODO // Name Service CosNaming::NamingContextExt_var nc; if (reference_is_ns_entry || !register_servant.empty()) { try { CORBA::Object_var ncObj = orb->resolve_initial_references("NameService"); nc = CosNaming::NamingContextExt::_narrow(ncObj); } catch(...) { } if (CORBA::is_nil(nc)) std::cerr << "Name service unavailable!" << std::endl; } // Proxy reference prueba::Iface_var reference; if (!proxy_reference.empty()) { CORBA::Object_var refObj; if (reference_is_ns_entry && !CORBA::is_nil(nc)) refObj = nc->resolve_str(proxy_reference.c_str()); else refObj = orb->string_to_object(proxy_reference.c_str()); reference = prueba::Iface::_narrow(refObj); } // Servant prueba_Iface_impl _impl(reference.in()); CORBA::Object_var rootPOAObj = orb->resolve_initial_references("RootPOA"); PortableServer::POA_var rootPOA = PortableServer::POA::_narrow(rootPOAObj.in()); PortableServer::POAManager_var manager = rootPOA->the_POAManager(); PortableServer::ObjectId_var myObjID = rootPOA->activate_object(&_impl); CORBA::Object_var obj = rootPOA->servant_to_reference(&_impl); // Displaying reference CORBA::String_var ref = orb->object_to_string(obj); std::cout << ref << std::endl; // Registring servant CosNaming::Name_var name; if (!register_servant.empty() && !CORBA::is_nil(nc)) { name = nc->to_name(register_servant.c_str()); nc->rebind(name, obj); } /*PROTECTED REGION ID(prueba_Iface_impl_server::___main) ENABLED START*/ /*PROTECTED REGION END*/ // Running manager->activate(); orb->run(); // Unbinding servant if (!CORBA::is_nil(nc) && name) nc->unbind(name); return 0; }
int TAO_Notify_Service_Driver::fini (void) { /// Release all the _vars as the ORB about to go away. CosNotifyChannelAdmin::EventChannelFactory_var factory = this->notify_factory_._retn (); CORBA::ORB_var orb = this->orb_._retn (); CORBA::ORB_var dispatching_orb = this->dispatching_orb_._retn (); PortableServer::POA_var poa = this->poa_._retn (); CosNaming::NamingContextExt_var naming = this->naming_._retn (); // This must be called to ensure that all services shut down // correctly. Depending upon the type of service loaded, it may // or may not actually perform any actions. this->notify_service_->finalize_service (factory.in ()); factory = CosNotifyChannelAdmin::EventChannelFactory::_nil (); this->notify_service_->fini (); // Deactivate. if (this->use_name_svc_ && !CORBA::is_nil (naming.in ())) { // Unbind all event channels from the naming service if (this->register_event_channel_) { for (ACE_Unbounded_Set<ACE_CString>::const_iterator ci ( this->notify_channel_name_); !ci.done(); ci++) { CosNaming::Name_var name = naming->to_name ((*ci).c_str ()); naming->unbind (name.in ()); } } // Unbind from the naming service. CosNaming::Name_var name = naming->to_name (this->notify_factory_name_.c_str ()); naming->unbind (name.in ()); naming = CosNaming::NamingContextExt::_nil (); } if (!CORBA::is_nil (poa.in ())) { poa->destroy (true, true); poa = PortableServer::POA::_nil (); } if (this->shutdown_dispatching_orb_ && !CORBA::is_nil (dispatching_orb_.in ())) { dispatching_orb->shutdown (); } // shutdown the ORB. if (this->shutdown_orb_ && !CORBA::is_nil (orb.in ())) { orb->shutdown (); } // Make sure all worker threads are gone. this->worker_.wait (); this->logging_worker_.wait (); // Destroy the ORB if (this->shutdown_dispatching_orb_ && !CORBA::is_nil (dispatching_orb_.in ())) { dispatching_orb->destroy (); } // Destroy the ORB. if (this->shutdown_orb_ && !CORBA::is_nil (orb.in ())) { orb->destroy (); } dispatching_orb_ = CORBA::ORB::_nil (); worker_.orb (CORBA::ORB::_nil ()); orb = CORBA::ORB::_nil (); return 0; }