sequence_ch.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 390 行
CPP
390 行
//
// sequence_ch.cpp,v 1.47 2003/12/31 20:25:58 bala Exp
//
// ============================================================================
//
// = LIBRARY
// TAO IDL
//
// = FILENAME
// sequence_ch.cpp
//
// = DESCRIPTION
// Visitor generating code for Sequence in the client header
//
// = AUTHOR
// Aniruddha Gokhale
//
// ============================================================================
ACE_RCSID (be_visitor_sequence,
sequence_ch,
"sequence_ch.cpp,v 1.47 2003/12/31 20:25:58 bala Exp")
// Root visitor for client header.
be_visitor_sequence_ch::be_visitor_sequence_ch (be_visitor_context *ctx)
: be_visitor_decl (ctx)
{
}
be_visitor_sequence_ch::~be_visitor_sequence_ch (void)
{
}
int be_visitor_sequence_ch::visit_sequence (be_sequence *node)
{
if (node->defined_in () == 0)
{
// The node is a nested sequence, and has had no scope defined.
node->set_defined_in (DeclAsScope (this->ctx_->scope ()));
}
// First create a name for ourselves.
if (node->create_name (this->ctx_->tdef ()) == -1)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_sequence_ch::"
"visit_sequence - "
"failed creating name\n"),
-1);
}
if (node->cli_hdr_gen () || node->imported ())
{
return 0;
}
be_type *bt = 0;
TAO_OutStream *os = this->ctx_->stream ();
// Retrieve the base type since we may need to do some code
// generation for the base type.
bt = be_type::narrow_from_decl (node->base_type ());
if (bt == 0)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_sequence_ch::"
"visit_sequence - "
"Bad element type\n"),
-1);
}
bt->seen_in_sequence (I_TRUE);
AST_Decl::NodeType nt = bt->node_type ();
// If our base type is an anonymouse sequence, we must create a name
// and generate a class declaration for it as well.
if (nt == AST_Decl::NT_sequence)
{
// Temporarily make the context's tdef node 0 so the nested call
// to create_name will not get confused and give our anonymous
// sequence element type the same name as we have.
be_typedef *tmp = this->ctx_->tdef ();
this->ctx_->tdef (0);
if (bt->accept (this) != 0)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_sequence_ch::"
"visit_sequence - "
"codegen for anonymous base type failed\n"),
-1);
}
// Restore the tdef value.
this->ctx_->tdef (tmp);
}
*os << be_nl << be_nl << "// TAO_IDL - Generated from" << be_nl
<< "// " << __FILE__ << ":" << __LINE__;
os->gen_ifdef_macro (node->flat_name ());
if (this->ctx_->tdef () != 0)
{
*os << be_nl << be_nl
<< "class " << node->local_name () << ";";
}
if (this->ctx_->tdef () != 0)
{
this->gen_varout_typedefs (node,
bt);
}
*os << be_nl << be_nl
<< "class " << be_global->stub_export_macro () << " "
<< node->local_name () << be_idt_nl
<< ": public" << be_idt << be_idt_nl;
if (node->gen_base_class_name (os, "", this->ctx_->scope ()) == -1)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_sequence_ch::"
"visit_sequence - "
"Base class name generation failed\n"),
-1);
}
*os << be_uidt << be_uidt << be_uidt;
*os << be_nl
<< "{" << be_nl
<< "public:" << be_idt;
*os << be_nl
<< node->local_name () << " (void);";
if (node->unbounded ())
{
*os << be_nl
<< node->local_name () << " (CORBA::ULong max);";
}
*os << be_nl
<< node->local_name () << " (" << be_idt << be_idt;
if (node->unbounded ())
{
*os << be_nl
<< "CORBA::ULong max,";
}
*os << be_nl
<< "CORBA::ULong length," << be_nl;
// Generate the base type for the buffer.
be_visitor_context ctx (*this->ctx_);
ctx.state (TAO_CodeGen::TAO_SEQUENCE_BUFFER_TYPE_CH);
be_visitor_sequence_buffer_type bt_visitor (&ctx);
if (bt->accept (&bt_visitor) == -1)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_sequence_ch::"
"visit_sequence - "
"base type visit failed\n"),
-1);
}
*os << "* buffer, " << be_nl
<< "CORBA::Boolean release = 0" << be_uidt_nl
<< ");" << be_uidt_nl;
*os << node->local_name () << " (const " << node->local_name ()
<< " &);" << be_nl;
*os << "~" << node->local_name () << " (void);";
if (be_global->any_support () && !node->anonymous ())
{
*os << be_nl << be_nl
<< "static void _tao_any_destructor (void *);";
}
// Generate the _var_type typedef (only if we are not anonymous).
if (this->ctx_->tdef () != 0)
{
*os << be_nl << be_nl
<< "typedef " << node->local_name () << "_var _var_type;";
}
// TAO provides extensions for octet sequences, first find out if
// the base type is an octet (or an alias for octet).
be_predefined_type *predef = 0;
if (bt->base_node_type () == AST_Type::NT_pre_defined)
{
be_typedef* alias =
be_typedef::narrow_from_decl (bt);
if (alias == 0)
{
predef = be_predefined_type::narrow_from_decl (bt);
}
else
{
predef =
be_predefined_type::narrow_from_decl (
alias->primitive_base_type ()
);
}
}
// Now generate the extension...
if (predef != 0 && predef->pt () == AST_PredefinedType::PT_octet
&& node->unbounded ())
{
*os << "\n\n#if (TAO_NO_COPY_OCTET_SEQUENCES == 1)" << be_nl
<< node->local_name () << " (" << be_idt << be_idt_nl
<< "CORBA::ULong length," << be_nl
<< "const ACE_Message_Block* mb" << be_uidt_nl
<< ")" << be_uidt_nl
<< " : TAO_Unbounded_Sequence<CORBA::Octet>"
<< " (length, mb) {}" << "\n"
<< "#endif /* TAO_NO_COPY_OCTET_SEQUENCE == 1 */";
}
*os << be_uidt_nl
<< "};";
os->gen_endif ();
node->cli_hdr_gen (1);
return 0;
}
void
be_visitor_sequence_ch::gen_varout_typedefs (be_sequence *node,
be_type *elem)
{
TAO_OutStream *os = this->ctx_->stream ();
be_decl *scope = this->ctx_->scope ();
*os << be_nl << be_nl;
switch (node->managed_type ())
{
case be_sequence::MNG_OBJREF:
*os << "typedef" << be_idt_nl
<< "TAO_MngSeq_Var_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< "TAO_Object_Manager<" << be_idt << be_idt_nl
<< elem->nested_type_name (scope) << "," << be_nl;
*os << elem->nested_type_name (scope, "_var") << be_uidt_nl << ">"
<< be_uidt << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_var;" << be_uidt;
*os << be_nl << be_nl
<< "typedef" << be_idt_nl
<< "TAO_MngSeq_Out_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< node->local_name () << "_var," << be_nl
<< "TAO_Object_Manager<" << be_idt << be_idt_nl
<< elem->nested_type_name (scope) << "," << be_nl;
*os << elem->nested_type_name (scope, "_var") << be_uidt_nl << ">"
<< be_uidt << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_out;" << be_uidt;
break;
case be_sequence::MNG_PSEUDO:
*os << "typedef" << be_idt_nl
<< "TAO_MngSeq_Var_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< "TAO_Pseudo_Object_Manager<" << be_idt << be_idt_nl
<< elem->nested_type_name (scope) << be_uidt_nl
<< ">" << be_uidt << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_var;" << be_uidt;
*os << be_nl << be_nl
<< "typedef" << be_idt_nl
<< "TAO_MngSeq_Out_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< node->local_name () << "_var," << be_nl
<< "TAO_Pseudo_Object_Manager<" << be_idt << be_idt_nl
<< elem->nested_type_name (scope) << be_uidt_nl
<< ">" << be_uidt << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_out;" << be_uidt;
break;
case be_sequence::MNG_VALUE:
*os << "typedef" << be_idt_nl
<< "TAO_MngSeq_Var_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< "TAO_Valuetype_Manager<" << be_idt << be_idt_nl
<< elem->nested_type_name (scope) << "," << be_nl;
*os << elem->nested_type_name (scope, "_var") << be_uidt_nl
<< ">" << be_uidt << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_var;" << be_uidt;
*os << be_nl << be_nl
<< "typedef" << be_idt_nl
<< "TAO_MngSeq_Out_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< node->local_name () << "_var," << be_nl
<< "TAO_Valuetype_Manager<" << be_idt << be_idt_nl
<< elem->nested_type_name (scope) << "," << be_nl;
*os << elem->nested_type_name (scope, "_var") << be_uidt_nl
<< ">" << be_uidt << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_out;" << be_uidt;
break;
case be_sequence::MNG_STRING:
*os << "typedef" << be_idt_nl
<< "TAO_MngSeq_Var_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< "TAO_SeqElem_String_Manager" << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_var;" << be_uidt;
*os << be_nl << be_nl
<< "typedef" << be_idt_nl
<< "TAO_MngSeq_Out_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< node->local_name () << "_var," << be_nl
<< "TAO_SeqElem_String_Manager" << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_out;" << be_uidt;
break;
case be_sequence::MNG_WSTRING:
*os << "typedef" << be_idt_nl
<< "TAO_MngSeq_Var_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< "TAO_SeqElem_WString_Manager" << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_var;" << be_uidt;
*os << be_nl << be_nl
<< "typedef" << be_idt_nl
<< "TAO_MngSeq_Out_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< node->local_name () << "_var," << be_nl
<< "TAO_SeqElem_WString_Manager" << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_out;" << be_uidt;
break;
default: // Not a managed type.
{
AST_Type::SIZE_TYPE st = elem->size_type ();
be_typedef *td = be_typedef::narrow_from_decl (elem);
if (td != 0)
{
AST_Decl::NodeType nt = elem->node_type ();
nt = td->base_node_type ();
}
*os << "typedef" << be_idt_nl
<< (st == AST_Type::FIXED ? "TAO_FixedSeq_Var_T<"
: "TAO_VarSeq_Var_T<")
<< be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< elem->nested_type_name (scope);
*os << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_var;" << be_uidt;
*os << be_nl << be_nl
<< "typedef" << be_idt_nl
<< "TAO_Seq_Out_T<" << be_idt << be_idt_nl
<< node->local_name () << "," << be_nl
<< node->local_name () << "_var," << be_nl
<< elem->nested_type_name (scope);
*os << be_uidt_nl
<< ">" << be_uidt_nl
<< node->local_name () << "_out;" << be_uidt;
}
break;
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?