2 #include "tao/IFR_Client/IFR_BaseC.h"
3 #include "tao/TypeCodeFactory/TypeCodeFactory_Loader.h"
5 #include "ace/Get_Opt.h"
10 const ACE_TCHAR
*ior
= ACE_TEXT("file://test.ior");
13 parse_args (int argc
, ACE_TCHAR
*argv
[])
15 ACE_Get_Opt
get_opts (argc
, argv
, ACE_TEXT("k:"));
18 while ((c
= get_opts ()) != -1)
22 ior
= get_opts
.opt_arg ();
28 ACE_ERROR_RETURN ((LM_ERROR
,
36 // Successful command line parsing.
40 template<typename T
> void dump (T
*); // Forward declaration.
44 perform_invocation (Test::Hello_ptr hello
,
45 CORBA::Any
const & the_any
)
47 // Execute more than once to help verify that mutable recursive
48 // TypeCode state is managed correctly.
49 for (unsigned int n
= 0; n
< 2; ++n
)
51 CORBA::Any_var my_any
=
52 hello
->get_any (the_any
);
55 if (!(my_any
.in () >>= my_foo
))
56 throw Test::Demarshaling_From_Any_Failed ();
58 CORBA::TypeCode_var the_tc
= the_any
.type ();
59 CORBA::TypeCode_var my_tc
= my_any
->type ();
61 CORBA::Boolean
const equal_tc
=
62 the_tc
->equal (my_tc
.in ());
65 throw Test::Recursive_Type_In_Any_Test_Failed ();
67 CORBA::Boolean
const equiv_tc
=
68 the_tc
->equivalent (my_tc
.in ());
71 throw Test::Recursive_Type_In_Any_Test_Failed ();
76 recursive_typecode_test (CORBA::ORB_ptr
/* orb */,
77 Test::Hello_ptr hello
)
80 "Executing recursive typecode test\n"));
84 Test::MyAttRefSequence test
;
87 attr
.attRefName
="attr";
88 attr
.attRefValue
.attrValue("value");
89 attr
.attRefQualifier
="atrQ1";
92 attr2
.attRefName
="attr2";
93 attr2
.attRefValue
.attrValue("value2");
94 attr2
.attRefQualifier
="atrQ2";
97 comp
.attRefName
="comp1";
98 comp
.attRefQualifier
="compQ";
100 Test::MyAttRef::MyAttRefValue::_compValue_seq
compSeq(1);
103 comp
.attRefValue
.compValue(compSeq
);
106 inti
.attRefName
="intval";
107 inti
.attRefValue
.intValue(0xAFFEAFFE);
116 ::perform_invocation
<Test::MyAttRefSequence
> (hello
, the_any
);
120 nested_recursive_typecode_test (CORBA::ORB_ptr
/* orb */,
121 Test::Hello_ptr hello
)
124 "Executing nested recursive typecode test\n"));
128 Test2::MyAttRefSeqStruct test
;
131 attr
.attRefName
="attr";
132 attr
.attRefValue
.attrValue("value");
133 attr
.attRefQualifier
="atrQ1";
135 Test::MyAttRef attr2
;
136 attr2
.attRefName
="attr2";
137 attr2
.attRefValue
.attrValue("value2");
138 attr2
.attRefQualifier
="atrQ2";
141 comp
.attRefName
="comp1";
142 comp
.attRefQualifier
="compQ";
144 Test::MyAttRef::MyAttRefValue::_compValue_seq
compSeq(1);
147 comp
.attRefValue
.compValue(compSeq
);
150 inti
.attRefName
="intval";
151 inti
.attRefValue
.intValue(0xAFFEAFFE);
153 test
.attRefSeq
.length(3);
154 test
.attRefSeq
[0] = comp
;
155 test
.attRefSeq
[1] = inti
;
156 test
.attRefSeq
[2] = attr
;
160 ::perform_invocation
<Test2::MyAttRefSeqStruct
> (hello
, the_any
);
166 * @brief Test method invocation functor.
168 * Test method invocation functor.
170 template <typename T
>
171 struct Caller
: public std::function
<void(T
)>
174 Caller (CORBA::ORB_ptr o
, Test::Hello_ptr h
)
175 : orb (CORBA::ORB::_duplicate (o
))
176 , hello (Test::Hello::_duplicate (h
))
181 /// Function call operator overload.
182 void operator() (T f
)
189 catch (const CORBA::Exception
& ex
)
191 ex
._tao_print_exception ("Exception thrown:");
198 Test::Hello_var hello
;
203 ACE_TMAIN(int argc
, ACE_TCHAR
*argv
[])
208 CORBA::ORB_init (argc
, argv
);
210 if (parse_args (argc
, argv
) != 0)
213 CORBA::Object_var tmp
=
214 orb
->string_to_object(ior
);
216 Test::Hello_var hello
=
217 Test::Hello::_narrow(tmp
.in ());
219 if (CORBA::is_nil (hello
.in ()))
221 ACE_ERROR_RETURN ((LM_DEBUG
,
222 "Nil Test::Hello reference <%s>\n",
227 typedef void (*test_func
) (CORBA::ORB_ptr
,
230 static test_func
const tests
[] =
232 recursive_typecode_test
,
233 nested_recursive_typecode_test
236 static size_t const test_count
= sizeof (tests
) / sizeof (test_func
);
238 // Have some fun with the STL. :-)
239 Caller
<test_func
> c
=
240 std::for_each (tests
,
242 Caller
<test_func
> (orb
.in (),
246 throw Test::Recursive_Type_In_Any_Test_Failed ();
252 catch (const CORBA::Exception
& ex
)
254 ex
._tao_print_exception ("Exception caught:");