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
|
// $Id$
#include "INSC.h"
#include "tao/ObjectIdListC.h"
#include "ace/Log_Msg.h"
#include "ace/OS_NS_string.h"
int
ACE_TMAIN (int argc, ACE_TCHAR *argv[])
{
int i = 0;
try
{
// Retrieve a reference to the ORB.
CORBA::ORB_var orb = CORBA::ORB_init (argc, argv);
if (argc < 2)
{
ACE_DEBUG ((LM_DEBUG,
"No Name specified to be resolved\n"));
return -1;
}
CORBA::Object_var objref;
for (i = 1; i < argc; ++i)
{
if (ACE_OS::strcmp (argv[i], ACE_TEXT("-l")) == 0)
{
// List initial services
CORBA::ORB::ObjectIdList_var list =
orb->list_initial_services ();
size_t length = list->length ();
if (length > 0)
{
ACE_DEBUG ((LM_INFO,
"Listing initial references...\n"));
for (CORBA::ULong n = 0; n < length; ++n)
{
ACE_DEBUG ((LM_DEBUG,
" Reference %u: %C\n",
n,
static_cast<char const*>(list[n])));
}
}
else
{
// We should at least get TAO's initial references,
// such as "RootPOA", "NameService", etc.
ACE_ERROR_RETURN ((LM_ERROR,
"\n"
"No initial references. "
"This condition shouldn't happen.\n"),
-1);
}
}
else
{
objref = orb->resolve_initial_references (ACE_TEXT_ALWAYS_CHAR(argv[i]));
if (CORBA::is_nil (objref.in ()))
ACE_ERROR_RETURN ((LM_ERROR,
" (%P|%t) Unable to resolve the "
"given name.\n"),
-1);
INS_var server = INS::_narrow (objref.in ());
CORBA::String_var iorstr =
orb->object_to_string (server.in ());
ACE_DEBUG ((LM_DEBUG,
"Resolved IOR for %s : %C\n",
argv[i],
iorstr.in()));
CORBA::String_var test_ins_result =
server->test_ins ();
ACE_DEBUG ((LM_DEBUG,
"\nResult of Remote Call : %C\n",
test_ins_result.in ()));
}
}
}
catch (const CORBA::ORB::InvalidName& )
{
ACE_DEBUG ((LM_DEBUG, "Cannot resolve <%s>\n", argv[i]));
}
catch (const CORBA::Exception& ex)
{
ex._tao_print_exception ("Exception:");
}
return 0;
}
|