Revert "Use a variable on the stack to not have a temporary in the call"
[ACE_TAO.git] / TAO / tests / Faults / ping.cpp
blob3e068a19d504fadfa16ad3d8eb1c18da57fd1b41
1 #include "ace/Get_Opt.h"
2 #include "ping_i.h"
3 #include "ace/OS_NS_stdio.h"
5 const ACE_TCHAR *ior_output_file = ACE_TEXT("ping.ior");
7 int
8 parse_args (int argc, ACE_TCHAR *argv[])
10 ACE_Get_Opt get_opts (argc, argv, ACE_TEXT("o:"));
11 int c;
13 while ((c = get_opts ()) != -1)
14 switch (c)
16 case 'o':
17 ior_output_file = get_opts.opt_arg ();
18 break;
20 case '?':
21 default:
22 ACE_ERROR_RETURN ((LM_ERROR,
23 "usage: %s "
24 "-o <iorfile>"
25 "\n",
26 argv [0]),
27 -1);
29 // Indicates successful parsing of the command line
30 return 0;
33 int
34 ACE_TMAIN(int argc, ACE_TCHAR *argv[])
36 try
38 CORBA::ORB_var orb =
39 CORBA::ORB_init (argc, argv);
41 CORBA::Object_var poa_object =
42 orb->resolve_initial_references("RootPOA");
44 PortableServer::POA_var root_poa =
45 PortableServer::POA::_narrow (poa_object.in ());
47 PortableServer::POAManager_var poa_manager =
48 root_poa->the_POAManager ();
50 poa_manager->activate ();
52 // create child poa with PERSISTENT policy
53 CORBA::PolicyList policies;
54 policies.length (2);
55 policies[0] =
56 root_poa->create_lifespan_policy(PortableServer::PERSISTENT);
58 policies[1] =
59 root_poa->create_implicit_activation_policy(PortableServer::IMPLICIT_ACTIVATION);
61 PortableServer::POA_var persistent_poa =
62 root_poa->create_POA("persistent",
63 poa_manager.in (),
64 policies);
65 policies[0]->destroy ();
66 policies[1]->destroy ();
68 poa_manager->activate ();
70 if (parse_args (argc, argv) != 0)
71 return 1;
73 PingObject_i *server_impl = 0;
74 ACE_NEW_RETURN (server_impl,
75 PingObject_i (orb.in (),
76 persistent_poa.in ()),
77 -1);
79 PortableServer::ServantBase_var owner_transfer(server_impl);
81 PortableServer::ObjectId_var id =
82 root_poa->activate_object (server_impl);
84 CORBA::Object_var object = root_poa->id_to_reference (id.in ());
86 PingObject_var server =
87 PingObject::_narrow (object.in ());
89 CORBA::String_var ior =
90 orb->object_to_string (server.in ());
92 ACE_DEBUG ((LM_DEBUG, "Activated as <%C>\n", ior.in ()));
94 // If the ior_output_file exists, output the ior to it
95 if (ior_output_file != 0)
97 FILE *output_file= ACE_OS::fopen (ior_output_file, "w");
98 if (output_file == 0)
99 ACE_ERROR_RETURN ((LM_ERROR,
100 "Cannot open output file for writing IOR: %s",
101 ior_output_file),
103 ACE_OS::fprintf (output_file, "%s", ior.in ());
104 ACE_OS::fclose (output_file);
107 orb->run ();
109 ACE_DEBUG ((LM_DEBUG, "ping - event loop finished\n"));
111 persistent_poa->destroy (true, true);
113 root_poa->destroy (true, true);
115 catch (const CORBA::Exception& ex)
117 ex._tao_print_exception ("Exception caught in ping:");
118 return 1;
121 return 0;