1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
// $Id$
// ============================================================================
//
// = LIBRARY
// TAO/tests
//
// = FILENAME
// server.cpp
//
// = AUTHOR
// Chris Cleeland
//
// ============================================================================
#include "tao/corba.h"
#include "tao/TAO.h"
#include "reactor_i.h"
int
main (int argc, char* argv[])
{
ACE_DEBUG ((LM_DEBUG,
"NestedUpcall server starting\n"));
TAO_TRY
{
#if defined(DONT_USE_ORBMGR)
// @@ Chris, can you please try to replace most of this boiler
// plate code with the TAO_Object_Manager stuff that Sumedh has
// devised? If we need to generalize his implementation to
// handle some of the things you do (e.g., create a special
// POAManager) please let me know.
CORBA::ORB_var orb =
CORBA::ORB_init (argc, argv, "server", TAO_TRY_ENV);
TAO_CHECK_ENV;
// Initialize the object adapter.
CORBA::Object_var poa_object =
orb->resolve_initial_references("RootPOA");
if (CORBA::is_nil (poa_object.in ()))
ACE_ERROR_RETURN ((LM_ERROR,
" (%P|%t) Unable to initialize the POA.\n"),
1);
PortableServer::POA_var root_poa =
PortableServer::POA::_narrow (poa_object.in(),
TAO_TRY_ENV);
TAO_CHECK_ENV;
PortableServer::POAManager_var poa_manager =
root_poa->the_POAManager (TAO_TRY_ENV);
TAO_CHECK_ENV;
CORBA::PolicyList policies (2);
policies.length (2);
policies[0] =
root_poa->create_id_assignment_policy (PortableServer::USER_ID,
TAO_TRY_ENV);
policies[1] =
root_poa->create_lifespan_policy (PortableServer::PERSISTENT,
TAO_TRY_ENV);
// We use a different POA, otherwise the user would have to
// change the object key each time it invokes the server.
PortableServer::POA_var poa =
root_poa->create_POA ("Persistent_POA",
poa_manager.in (),
policies,
TAO_TRY_ENV);
TAO_CHECK_ENV;
#else
TAO_ORB_Manager om;
om.init_child_poa (argc, argv, "Persistent_POA", TAO_TRY_ENV);
TAO_CHECK_ENV;
CORBA_ORB_var orb = om.orb ();
#endif
// Now that we've got all that done, we need to create our impl
// and register!
Reactor_i *reactor_impl = 0;
ACE_NEW_RETURN (reactor_impl, Reactor_i, -1);
#if defined(DONT_USE_ORBMGR)
PortableServer::ObjectId_var id =
PortableServer::string_to_ObjectId ("Reactor");
poa->activate_object_with_id (id.in (),
reactor_impl, TAO_TRY_ENV);
#else
CORBA::String s = om.activate_under_child_poa ("Reactor", reactor_impl, TAO_TRY_ENV);
CORBA::string_free (s);
#endif
TAO_CHECK_ENV;
// Stringify the object
Reactor_ptr reactor = reactor_impl->_this (TAO_TRY_ENV);
TAO_CHECK_ENV;
CORBA::String_var str =
orb->object_to_string (reactor, TAO_TRY_ENV);
TAO_CHECK_ENV;
ACE_DEBUG ((LM_DEBUG,
"(%P|%t) The reactor IOR is <%s>\n",
str.in ()));
// Run the server now.
#if defined(DONT_USE_ORBMGR)
orb->run ();
#else
om.run (TAO_TRY_ENV);
#endif
CORBA::release (reactor);
}
TAO_CATCHANY
{
TAO_TRY_ENV.print_exception ("orb_init");
return -1;
}
TAO_ENDTRY;
ACE_DEBUG ((LM_DEBUG, "NestedUpcall server ending\n"));
return 0;
}
|