arglist.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 203 行
CPP
203 行
//
// arglist.cpp,v 1.33 2003/10/28 18:30:38 bala Exp
//
// ============================================================================
//
// = LIBRARY
// TAO IDL
//
// = FILENAME
// arglist.cpp
//
// = DESCRIPTION
// Visitor generating code for the parameter list of the Operation signature.
//
// = AUTHOR
// Aniruddha Gokhale
//
// ============================================================================
ACE_RCSID (be_visitor_operation,
arglist,
"arglist.cpp,v 1.33 2003/10/28 18:30:38 bala Exp")
// ************************************************************
// operation visitor to generate the argument list.
// We have separated code generation for this from the 4 main
// visitors to avoid code duplication and tight coupling
// ************************************************************
be_visitor_operation_arglist::be_visitor_operation_arglist (
be_visitor_context *ctx
)
: be_visitor_operation (ctx)
{
}
be_visitor_operation_arglist::~be_visitor_operation_arglist (void)
{
}
int
be_visitor_operation_arglist::visit_operation (be_operation *node)
{
TAO_OutStream *os = this->ctx_->stream ();
*os << " (" << be_idt << be_idt_nl;
int arg_emitted = 0;
switch (this->ctx_->state ())
{
case TAO_CodeGen::TAO_OPERATION_ARGLIST_PROXY_IMPL_XH:
case TAO_CodeGen::TAO_OPERATION_ARGLIST_PROXY_IMPL_XS:
*os << "CORBA::Object *_collocated_tao_target_";
if (node->argument_count () > 0)
{
*os << "," << be_nl;
}
arg_emitted = 1;
break;
default:
break;
}
// All we do is hand over code generation to our scope.
if (this->visit_scope (node) == -1)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_operation_arglist::"
"visit_operation - "
"codegen for scope failed\n"),
-1);
}
if (this->gen_environment_decl (arg_emitted, node) == -1)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_operation_arglist::"
"visit_operation - "
"gen_environment_decl failed\n"),
-1);
}
*os << be_uidt_nl
<< ")";
// Now generate the throw specs.
if (this->gen_throw_spec (node) == -1)
{
ACE_ERROR_RETURN ((LM_ERROR,
ACE_TEXT ("(%N:%l) be_visitor_operation_arglist")
ACE_TEXT ("::visit_operation - ")
ACE_TEXT ("Failed to generate throw spec\n")),
-1);
}
switch (this->ctx_->state ())
{
case TAO_CodeGen::TAO_OPERATION_ARGLIST_CH:
case TAO_CodeGen::TAO_OPERATION_ARGLIST_COLLOCATED_SH:
case TAO_CodeGen::TAO_OPERATION_ARGLIST_IH:
if (node->is_local ())
{
*os << " = 0;";
}
else
{
*os << ";";
}
break;
case TAO_CodeGen::TAO_OPERATION_ARGLIST_PROXY_IMPL_XH:
*os << ";";
break;
case TAO_CodeGen::TAO_OPERATION_ARGLIST_SH:
// Each method is pure virtual in the server header.
*os << " = 0;";
break;
case TAO_CodeGen::TAO_OPERATION_ARGLIST_IS:
case TAO_CodeGen::TAO_OPERATION_ARGLIST_PROXY_IMPL_XS:
default:
break;
}
return 0;
}
int
be_visitor_operation_arglist::visit_argument (be_argument *node)
{
// Get the visitor that will dump the argument's mapping in the operation
// signature.
be_visitor_context ctx (*this->ctx_);
// First grab the interface definition inside which this operation is
// defined. We need this since argument types may very well be declared
// inside the scope of the interface node. In such cases, we would like to
// generate the appropriate relative scoped names.
be_operation *op = this->ctx_->be_scope_as_operation ();
if (!op)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_arglist::"
"visit_argument - "
"Bad operation\n"),
-1);
}
// We need the interface node in which this operation was defined. However,
// if this operation node was an attribute node in disguise, we get this
// information from the context
be_interface *intf;
intf = this->ctx_->attribute ()
? be_interface::narrow_from_scope (this->ctx_->attribute ()->defined_in ())
: be_interface::narrow_from_scope (op->defined_in ());
if (!intf)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_arglist::"
"visit_argument - "
"Bad interface\n"),
-1);
}
// Set new scope.
ctx.scope (intf);
// Create a visitor.
be_visitor_args_arglist visitor (&ctx);
if (visitor.visit_argument (node) == -1)
{
ACE_ERROR_RETURN ((LM_ERROR,
"(%N:%l) be_visitor_arglist::"
"visit_argument - "
"codegen for arglist failed\n"),
-1);
}
return 0;
}
int
be_visitor_operation_arglist::post_process (be_decl *bd)
{
TAO_OutStream *os = this->ctx_->stream ();
// if we are not the last node in the list of arguments, generate a comma
// else decide if we are generating code to support true exceptions - in
// which case there will not be any CORBA::Environment parameter
if (!this->last_node (bd))
{
*os << "," << be_nl;
}
return 0;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?