summaryrefslogtreecommitdiff
path: root/TAO/examples/Content_Server/AMI_Observer/server.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/examples/Content_Server/AMI_Observer/server.cpp')
-rw-r--r--TAO/examples/Content_Server/AMI_Observer/server.cpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/TAO/examples/Content_Server/AMI_Observer/server.cpp b/TAO/examples/Content_Server/AMI_Observer/server.cpp
new file mode 100644
index 00000000000..e3cc88d906e
--- /dev/null
+++ b/TAO/examples/Content_Server/AMI_Observer/server.cpp
@@ -0,0 +1,76 @@
+// -*- C++ -*-
+// $Id$
+
+// Ossama Othman <ossama@uci.edu>
+
+#include "orbsvcs/CosNamingC.h"
+#include "Push_Web_ServerS.h"
+#include "Push_Iterator_Factory_i.h"
+
+ACE_RCSID (AMI_Observer,
+ server,
+ "$Id$")
+
+int
+main (int argc, char *argv[])
+{
+ try
+ {
+ // Initialize the ORB.
+ CORBA::ORB_var orb = CORBA::ORB_init (argc,
+ argv,
+ "Mighty ORB");
+
+ // Get the Root POA.
+ CORBA::Object_var obj =
+ orb->resolve_initial_references ("RootPOA");
+
+ PortableServer::POA_var poa =
+ PortableServer::POA::_narrow (obj.in ());
+
+ // Activate the POA manager.
+ PortableServer::POAManager_var mgr = poa->the_POAManager ();
+ mgr->activate ();
+
+ // Create the Iterator_Factory servant and object.
+ Push_Iterator_Factory_i factory_servant;
+ Web_Server::Iterator_Factory_var factory =
+ factory_servant._this ();
+
+ // Get a reference to the Name Service.
+ obj = orb->resolve_initial_references ("NameService");
+
+ // Narrow to a Naming Context
+ CosNaming::NamingContext_var nc =
+ CosNaming::NamingContext::_narrow (obj.in ());
+
+ // Create a name.
+ CosNaming::Name name;
+ name.length (1);
+ name[0].id = CORBA::string_dup ("Push_Iterator_Factory");
+ name[0].kind = CORBA::string_dup ("");
+
+ nc->bind (name, factory.in ());
+
+ // Some debugging output.
+ CORBA::String_var IOR = orb->object_to_string (factory.in ());
+ ACE_DEBUG ((LM_DEBUG,
+ ACE_TEXT ("Bound <%s> to <%s> in Name Service.\n"),
+ name[0].id.in (),
+ IOR.in ()));
+
+ ACE_DEBUG ((LM_INFO,
+ ACE_TEXT ("Accepting requests.\n")));
+
+ // Accept requests.
+ orb->run ();
+ }
+ catch (const CORBA::Exception& ex)
+ {
+ ex._tao_print_exception (ACE_TEXT ("Caught unexpected exception:"));
+
+ return -1;
+ }
+
+ return 0;
+}