summaryrefslogtreecommitdiff
path: root/TAO/examples/POA/On_Demand_Loading/server.cpp
blob: 7a0cb24ed35f57328b3a65b688355f242af8f96c (plain)
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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
// $Id$

//============================================================================
//
// = FILENAME
//     server.cpp
//
// = DESCRIPTION
//     Server to test the Servant Activator and Servant Locator for a POA.
//
// = AUTHOR
//     Kirthika Parameswaran <kirthika@cs.wustl.edu>
//
//=============================================================================

#include "ace/streams.h"
#include "Servant_Activator.h"
#include "Servant_Locator.h"

ACE_RCSID(On_Demand_Loading, server, "$Id$")

static char *ior_output_file = 0;

static int
parse_args (int argc, char **argv)
{
  ACE_Get_Opt get_opts (argc, argv, "f:");
  int c;

  while ((c = get_opts ()) != -1)
    switch (c)
      {
      case 'f':
        ior_output_file = get_opts.optarg;
        break;

      case '?':
      default:
        ACE_ERROR_RETURN ((LM_ERROR,
                           "usage:  %s "
                           "[-f ior_output_file] "
                           "\n",
                           argv [0]),
                          -1);
      }

  // Indicates successful parsing of command line.
  return 0;
}

static int
write_iors_to_file (const char *first_ior,
                    const char *second_ior)
{
  if (ior_output_file == 0)
    // No filename was specified; simply return
    return 0;

  char ior_output_file_1[BUFSIZ];
  char ior_output_file_2[BUFSIZ];

  ACE_OS::sprintf (ior_output_file_1, "%s_1", ior_output_file);
  ACE_OS::sprintf (ior_output_file_2, "%s_2", ior_output_file);

  FILE *output_file_1 = ACE_OS::fopen (ior_output_file_1, "w");
  FILE *output_file_2 = ACE_OS::fopen (ior_output_file_2, "w");

  if (output_file_1 == 0 ||
      output_file_2 == 0)
    ACE_ERROR_RETURN ((LM_ERROR, "Cannot open output files for writing IORs: %s, %s\n",
                       ior_output_file_1,
                       ior_output_file_2),
                      -1);

  int result = ACE_OS::fprintf (output_file_1,
				"%s",
				first_ior);
  if (result <= 0
      || ACE_static_cast (size_t,result) != ACE_OS::strlen (first_ior))
    ACE_ERROR_RETURN ((LM_ERROR,
                       "ACE_OS::fprintf failed while writing %s to %s\n",
                       first_ior,
                       ior_output_file_1),
                      -1);

  result = ACE_OS::fprintf (output_file_2,
                            "%s",
                            second_ior);
  if (result <= 0
      || ACE_static_cast (size_t,result) != ACE_OS::strlen (second_ior))
    ACE_ERROR_RETURN ((LM_ERROR,
                       "ACE_OS::fprintf failed while writing %s to %s\n",
                       second_ior,
                       ior_output_file_2),
                      -1);
  ACE_OS::fclose (output_file_1);
  ACE_OS::fclose (output_file_2);
  return 0;
}

int
main (int argc, char **argv)
{
  CORBA::Environment TAO_TRY_ENV;

  TAO_TRY
    {
      // Initialize the ORB.
      CORBA::ORB_var orb =
        CORBA::ORB_init (argc, argv, 0, TAO_TRY_ENV); 
      TAO_CHECK_ENV;

      int result = parse_args (argc, argv);
      if (result != 0)
        return result;

      // Get an Object reference to RootPOA.
      CORBA::Object_var obj =
        orb->resolve_initial_references ("RootPOA");

      // Narrow the Object reference to a POA reference
      PortableServer::POA_var root_poa =
        PortableServer::POA::_narrow (obj.in (),
                                      TAO_TRY_ENV);  
      TAO_CHECK_ENV;
  
      // Get the POAManager of RootPOA

      PortableServer::POAManager_var poa_manager =
        root_poa->the_POAManager (TAO_TRY_ENV);
  
      TAO_CHECK_ENV;

      CORBA::PolicyList policies (4);
      policies.length (4);

      // ID Assignment Policy
      policies[0] =
        root_poa->create_id_assignment_policy (PortableServer::USER_ID,
                                               TAO_TRY_ENV);
      TAO_CHECK_ENV;

      // Lifespan Policy
      policies[1] =
        root_poa->create_lifespan_policy (PortableServer::PERSISTENT,
                                          TAO_TRY_ENV);
      TAO_CHECK_ENV;
  
      // Request Processing Policy
      policies[2] =
        root_poa->create_request_processing_policy (PortableServer::USE_SERVANT_MANAGER,
                                                    TAO_TRY_ENV);
      TAO_CHECK_ENV;

      // @@ Kirthika, can you please break this giant function up into
      // several smaller functions, e.g., put the initialization
      // methods first in their own function, then put the POA
      // creation methods next, perhaps in their own functions,
      // followed finally by the other initialization.
      PortableServer::POA_var first_poa;
      {
        // Servant Retention Policy
        policies[3] =
          root_poa->create_servant_retention_policy (PortableServer::RETAIN,
                                                     TAO_TRY_ENV);
        TAO_CHECK_ENV;

        // Create firstPOA as the child of RootPOA with the above
        // policies firstPOA will use SERVANT_ACTIVATOR because of
        // RETAIN policy.
        first_poa = root_poa->create_POA ("firstPOA",
                                          poa_manager.in (),
                                          policies,
                                          TAO_TRY_ENV);
        TAO_CHECK_ENV;
      }

      PortableServer::POA_var second_poa;
      {
        // Servant Retention Policy
        policies[3] =
          root_poa->create_servant_retention_policy (PortableServer::NON_RETAIN,
                                                     TAO_TRY_ENV);
        TAO_CHECK_ENV;
  
        // Create secondPOA as child of RootPOA with the above policies
        // secondPOA will use a SERVANT_LOCATOR because of NON_RETAIN
        // policy.
        second_poa = root_poa->create_POA ("secondPOA",
                                           poa_manager.in (),
                                           policies,
                                           TAO_TRY_ENV);
        TAO_CHECK_ENV;
   
        // Destroy the policy objects as they have been passed to
        // create_POA and no longer needed.
        for (CORBA::ULong i = 0;
             i < policies.length () && TAO_TRY_ENV.exception () == 0;
             ++i)
          {
            CORBA::Policy_ptr policy = policies[i];
            policy->destroy (TAO_TRY_ENV);
          }

        TAO_CHECK_ENV;
  
        // @@ *done*Kirthika, please add a comment here.
        // An Servant Activator object is created which will activate 
        // the servant on demand.
        ServantActivator_i servant_activator_impl (orb.in ());

        PortableServer::ServantActivator_var servant_activator =
          servant_activator_impl._this (TAO_TRY_ENV);
        TAO_CHECK_ENV;
 
        // Set ServantActivator_i object as the servant_manager of
        // firstPOA.
        first_poa->set_servant_manager (servant_activator.in (),
                                        TAO_TRY_ENV);
        TAO_CHECK_ENV;
  
        // Create a reference with user created ID in firstPOA which
        // uses the MyFooServantActivator. The servant dll name as
        // well as the factory function in the dll are used in
        // creating the objectId.

         ACE_DEBUG ((LM_DEBUG,
              "create object id to be done\n"));
        PortableServer::ObjectId_var first_foo_oid =
          servant_activator_impl.create_dll_object_id ("MyFoo",
                                                       "create_MyFoo");

         ACE_DEBUG ((LM_DEBUG,
              "create object id done\n"));
        CORBA::Object_var first_foo =
          first_poa->create_reference_with_id (first_foo_oid.in (),
                                               "IDL:Foo:1.0",
                                               TAO_TRY_ENV);
        TAO_CHECK_ENV;
  
        // @@*done* Kirthika, please add a comment here.
        // An Servant Locator object is created which will activate 
        // the servant on demand.
        ServantLocator_i servant_locator_impl (orb.in ());

        PortableServer::ServantLocator_var servant_locator =
          servant_locator_impl._this (TAO_TRY_ENV);
        TAO_CHECK_ENV;

        // Set ServantLocator_i object as the servant Manager of
        // secondPOA.

        second_poa->set_servant_manager (servant_locator.in (),
                                         TAO_TRY_ENV);
        TAO_CHECK_ENV;

        // Try to create a reference with user created ID in
        // second_poa which uses MyFooServantLocator. The servant dll
        // name as well as the factory function in the dll are used in
        // creating the objectId.
        PortableServer::ObjectId_var second_foo_oid =
          servant_locator_impl.create_dll_object_id ("MyFoo",
                                                     "create_MyFoo");
        CORBA::Object_var second_foo =
          second_poa->create_reference_with_id (second_foo_oid.in (),
                                                "IDL:Foo:1.0",
                                                TAO_TRY_ENV);
        TAO_CHECK_ENV;

        // Invoke object_to_string on the references created in
        // firstPOA and secondPOA.

        CORBA::String_var first_foo_ior =
          orb->object_to_string (first_foo.in (),
                                 TAO_TRY_ENV);
        TAO_CHECK_ENV;
  
        CORBA::String_var second_foo_ior =
          orb->object_to_string (second_foo.in (),
                                 TAO_TRY_ENV);
        TAO_CHECK_ENV;
  
        // Print the ior's of first_foo and second_foo.

        ACE_DEBUG ((LM_DEBUG,"%s\n%s\n",
                    first_foo_ior.in (),
                    second_foo_ior.in ()));

        int write_result = write_iors_to_file (first_foo_ior.in (),
                                               second_foo_ior.in ());
        if (write_result != 0)
          return write_result;

        // Set the poa_manager state to active, ready to process
        // requests.
        poa_manager->activate (TAO_TRY_ENV);

        TAO_CHECK_ENV;
  
        // Run the ORB.
        if (orb->run () == -1)
          ACE_ERROR_RETURN ((LM_ERROR,
                             "%p\n",
                             "CORBA::ORB::run"),
                            -1);
        // Destroy the root_poa and also first_poa and second_poa.
        root_poa->destroy (1,
                           1,
                           TAO_TRY_ENV);
        TAO_CHECK_ENV;
      }
    }
  TAO_CATCHANY 
    {
      TAO_TRY_ENV.print_exception ("server:main ()");
      return 1;
    }
  TAO_ENDTRY;
  
  return 0;
}