summaryrefslogtreecommitdiff
path: root/TAO/TAO_IDL/be/be_visitor_traits.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/TAO_IDL/be/be_visitor_traits.cpp')
-rw-r--r--TAO/TAO_IDL/be/be_visitor_traits.cpp57
1 files changed, 32 insertions, 25 deletions
diff --git a/TAO/TAO_IDL/be/be_visitor_traits.cpp b/TAO/TAO_IDL/be/be_visitor_traits.cpp
index f3dc9b10f79..09b0e02f2a3 100644
--- a/TAO/TAO_IDL/be/be_visitor_traits.cpp
+++ b/TAO/TAO_IDL/be/be_visitor_traits.cpp
@@ -99,6 +99,8 @@ be_visitor_traits::visit_interface (be_interface *node)
*os << be_nl << be_nl << "// TAO_IDL - Generated from" << be_nl
<< "// " << __FILE__ << ":" << __LINE__;
+ os->gen_ifdef_macro (node->flat_name (), "arg_traits");
+
// Since the three blocks below generate specialized (i.e., non-template)
// classes, we don't want to generate them unless it's necessary - thus
// the logic surrounding each one.
@@ -108,7 +110,7 @@ be_visitor_traits::visit_interface (be_interface *node)
if (!node->imported ())
{
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "struct " << be_global->stub_export_macro () << " Objref_Traits<"
<< node->name () << ">" << be_nl
<< "{" << be_idt_nl
@@ -131,10 +133,8 @@ be_visitor_traits::visit_interface (be_interface *node)
// multiple declarations.
if (node->seen_in_operation ())
{
- os->gen_ifdef_macro (node->flat_name (), "arg_traits");
-
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< node->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl
@@ -145,10 +145,10 @@ be_visitor_traits::visit_interface (be_interface *node)
<< ">" << be_uidt << be_uidt << be_uidt << be_uidt_nl
<< "{" << be_nl
<< "};";
-
- os->gen_endif ();
}
+ os->gen_endif ();
+
int status = this->visit_scope (node);
if (status != 0)
@@ -204,12 +204,14 @@ be_visitor_traits::visit_valuetype (be_valuetype *node)
*os << be_nl << be_nl << "// TAO_IDL - Generated from" << be_nl
<< "// " << __FILE__ << ":" << __LINE__;
+ os->gen_ifdef_macro (node->flat_name (), "arg_traits");
+
// This is used by the _var and _out classes, so it should always be
// generated in the main file.
if (!node->imported ())
{
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "struct " << be_global->stub_export_macro () << " Value_Traits<"
<< node->name () << ">" << be_nl
<< "{" << be_idt_nl
@@ -223,10 +225,8 @@ be_visitor_traits::visit_valuetype (be_valuetype *node)
// multiple declarations.
if (node->seen_in_operation ())
{
- os->gen_ifdef_macro (node->flat_name (), "arg_traits");
-
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< node->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl
@@ -237,10 +237,10 @@ be_visitor_traits::visit_valuetype (be_valuetype *node)
<< ">" << be_uidt << be_uidt << be_uidt << be_uidt_nl
<< "{" << be_nl
<< "};";
-
- os->gen_endif ();
}
+ os->gen_endif ();
+
int status = this->visit_scope (node);
if (status != 0)
@@ -307,8 +307,10 @@ be_visitor_traits::visit_sequence (be_sequence *node)
*os << be_nl << be_nl << "// TAO_IDL - Generated from" << be_nl
<< "// " << __FILE__ << ":" << __LINE__;
+ os->gen_ifdef_macro (node->flat_name (), "arg_traits");
+
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< node->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl
@@ -320,6 +322,8 @@ be_visitor_traits::visit_sequence (be_sequence *node)
<< "{" << be_nl
<< "};";
+ os->gen_endif ();
+
node->cli_traits_gen (I_TRUE);
return 0;
}
@@ -343,15 +347,17 @@ be_visitor_traits::visit_string (be_string *node)
return 0;
}
+ idl_bool wide = (node->width () != 1);
+
TAO_OutStream *os = this->ctx_->stream ();
*os << be_nl << be_nl << "// TAO_IDL - Generated from" << be_nl
<< "// " << __FILE__ << ":" << __LINE__;
- idl_bool wide = (node->width () != 1);
+ os->gen_ifdef_macro (node->flat_name (), "arg_traits");
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< alias->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl
@@ -361,6 +367,8 @@ be_visitor_traits::visit_string (be_string *node)
<< "{" << be_nl
<< "};";
+ os->gen_endif ();
+
node->cli_traits_gen (I_TRUE);
return 0;
}
@@ -379,12 +387,14 @@ be_visitor_traits::visit_array (be_array *node)
*os << be_nl << be_nl << "// TAO_IDL - Generated from" << be_nl
<< "// " << __FILE__ << ":" << __LINE__;
+ os->gen_ifdef_macro (node->flat_name (), "arg_traits");
+
// This is used by the _var and _out classes, so it should always be
// generated in the main file.
if (!node->imported ())
{
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "struct " << be_global->stub_export_macro () << " Array_Traits<"
<< be_idt << be_idt_nl
<< node->name () << "," << be_nl
@@ -408,10 +418,8 @@ be_visitor_traits::visit_array (be_array *node)
// multiple declarations.
if (node->seen_in_operation ())
{
- os->gen_ifdef_macro (node->flat_name (), "arg_traits");
-
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< node->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl;
@@ -431,10 +439,10 @@ be_visitor_traits::visit_array (be_array *node)
<< ">" << be_uidt << be_uidt << be_uidt << be_uidt_nl
<< "{" << be_nl
<< "};";
-
- os->gen_endif ();
}
+ os->gen_endif ();
+
node->cli_traits_gen (I_TRUE);
return 0;
}
@@ -457,7 +465,7 @@ be_visitor_traits::visit_enum (be_enum *node)
os->gen_ifdef_macro (node->flat_name (), "arg_traits");
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< node->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl;
@@ -494,7 +502,7 @@ be_visitor_traits::visit_structure (be_structure *node)
os->gen_ifdef_macro (node->flat_name (), "arg_traits");
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< node->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl;
@@ -580,7 +588,7 @@ be_visitor_traits::visit_union (be_union *node)
os->gen_ifdef_macro (node->flat_name (), "arg_traits");
*os << be_nl << be_nl
- << "template<>" << be_nl
+ << "ACE_TEMPLATE_SPECIALIZATION" << be_nl
<< "class " << be_global->stub_export_macro () << " Arg_Traits<"
<< node->name () << ">" << be_idt_nl
<< ": public" << be_idt << be_idt_nl;
@@ -642,7 +650,6 @@ be_visitor_traits::visit_union_branch (be_union_branch *node)
}
node->cli_traits_gen (I_TRUE);
- bt->cli_traits_gen (I_TRUE);
return 0;
}