⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 interface_sh.cpp

📁 这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用于网络游戏医学图像网关的高qos要求.更详细的内容可阅读相应的材料
💻 CPP
字号:
//
// interface_sh.cpp,v 1.53 2003/10/28 18:30:37 bala Exp
//

// ============================================================================
//
// = LIBRARY
//    TAO IDL
//
// = FILENAME
//    interface_sh.cpp
//
// = DESCRIPTION
//    Visitor generating code for Interfaces in the server header
//
// = AUTHOR
//    Aniruddha Gokhale
//
// ============================================================================

ACE_RCSID (be_visitor_interface, 
           interface_sh, 
           "interface_sh.cpp,v 1.53 2003/10/28 18:30:37 bala Exp")

// ************************************************************
// Interface visitor for server header.
// ************************************************************

be_visitor_interface_sh::be_visitor_interface_sh (be_visitor_context *ctx)
  : be_visitor_interface (ctx)
{
}

be_visitor_interface_sh::~be_visitor_interface_sh (void)
{
}

int
be_visitor_interface_sh::visit_interface (be_interface *node)
{
  if (node->srv_hdr_gen () 
      || node->imported ())
    {
      return 0;
    }

  // For abstract interfaces, we just generated the collocation stuff
  // (see below).
  if (! node->is_abstract ())
    {
    // If this node is a AMH-RH node, then generate code for it
    if (node->is_local ())
      {
        if (this->is_amh_rh_node (node))
          {
            // Create amh_rh_visitors.
            be_visitor_amh_rh_interface_sh amh_rh_intf (this->ctx_);
            amh_rh_intf.visit_interface (node);
          }

        return 0;
      }

    if (this->generate_amh_classes (node) == -1)
      {
        ACE_ERROR_RETURN ((LM_ERROR,
                           "be_visitor_interface_sh::"
                           "visit_interface - "
                           "codegen for AMH classes failed\n"),
                          -1);
      }

    TAO_OutStream *os  = this->ctx_->stream ();
    ACE_CString class_name;

    // We shall have a POA_ prefix only if we are at the topmost level.
    if (!node->is_nested ())
      {
        // We are outermost.
        class_name += "POA_";
        class_name += node->local_name ();
      }
    else
      {
        class_name +=  node->local_name ();
      }

    *os << be_nl << be_nl
        << "// TAO_IDL - Generated from" << be_nl
        << "// " << __FILE__ << ":" << __LINE__ << be_nl << be_nl;

    // Generate the skeleton class name.
    *os << "class " << class_name.c_str () << ";" << be_nl;

    // Generate the _ptr declaration.
    *os << "typedef " << class_name.c_str () << " *" << class_name.c_str ()
        << "_ptr;" << be_nl << be_nl;

    // Forward class declarations.
    if (be_global->gen_thru_poa_collocation ())
      {
        *os << "class " << node->thru_poa_proxy_impl_name () << ";" << be_nl;
      }

    if (be_global->gen_direct_collocation ())
      {
        *os << "class " << node->direct_proxy_impl_name () << ";" << be_nl;
      }

    if (be_global->gen_thru_poa_collocation ()
        || be_global->gen_direct_collocation ())
      {
        *os << "class " << node->strategized_proxy_broker_name ()
            << ";" << be_nl;
      }

    *os << be_nl;

    // Now generate the class definition.
    *os << "class " << be_global->skel_export_macro ()
        << " " << class_name.c_str () << be_idt_nl << ": " << be_idt;

    long n_parents = node->n_inherits ();
    AST_Interface *parent = 0;
    int has_concrete_parent = 0;

    for (int i = 0; i < n_parents; ++i)
      {
        parent = node->inherits ()[i];
      
        if (parent->is_abstract ())
          {
            continue;
          }

        if (has_concrete_parent == 1)
          {
            *os << "," << be_nl;
          }

        *os << "public virtual " << "POA_"
            << parent->name ();

        has_concrete_parent = 1;
      }

    if (has_concrete_parent == 0)
      {
        // We don't inherit from another user defined object, hence our
        // base class is the ServantBase class.
        *os << "public virtual PortableServer::ServantBase";
      }

    *os << be_uidt << be_uidt_nl
        << "{" << be_nl
        << "protected:" << be_idt_nl;

    // Default constructor.
    *os << class_name.c_str () << " (void);" << be_uidt_nl << be_nl
        << "public:" << be_idt_nl;

    // Some useful typedefs.
    *os << "// Useful for template programming." << be_nl
        << "typedef ::" << node->name () << " _stub_type;" << be_nl
        << "typedef ::" << node->name () << "_ptr _stub_ptr_type;" << be_nl
        << "typedef ::" << node->name () << "_var _stub_var_type;" 
        << be_nl << be_nl;

    // Copy constructor and destructor.
    *os << class_name.c_str () << " (const " 
        << class_name.c_str () << "& rhs);" << be_nl
        << "virtual ~" << class_name.c_str () << " (void);" << be_nl << be_nl;

    // _is_a
    *os << "virtual CORBA::Boolean _is_a (" << be_idt << be_idt_nl
        << "const char* logical_type_id" << be_nl
        << "ACE_ENV_ARG_DECL_WITH_DEFAULTS" << be_uidt_nl
        << ");" << be_uidt_nl << be_nl;

    // _downcast
    *os << "virtual void* _downcast (" << be_idt << be_idt_nl
        << "const char* logical_type_id" << be_uidt_nl
        << ");" << be_uidt_nl << be_nl;

    // Add a skeleton for our _is_a method.
    *os << "static void _is_a_skel (" << be_idt << be_idt_nl
        << "TAO_ServerRequest &req," << be_nl
        << "void *servant," << be_nl
        << "void *servant_upcall" << be_nl
        << "ACE_ENV_ARG_DECL" << be_uidt_nl
        << ");" << be_uidt_nl << be_nl;

    // Add a skeleton for our _non_existent method.
    *os << "static void _non_existent_skel (" << be_idt << be_idt_nl
        << "TAO_ServerRequest &req," << be_nl
        << "void *servant," << be_nl
        << "void *servant_upcall" << be_nl
        << "ACE_ENV_ARG_DECL" << be_uidt_nl
        << ");" << be_uidt_nl << be_nl;

    // Add a skeleton for our _interface method.
    *os << "static void _interface_skel (" << be_idt << be_idt_nl
        << "TAO_ServerRequest &req," << be_nl
        << "void *servant," << be_nl
        << "void *servant_upcall" << be_nl
        << "ACE_ENV_ARG_DECL" << be_uidt_nl
        << ");" << be_uidt_nl << be_nl;

    // Add a skeleton for our _component method.
    *os << "static void _component_skel (" << be_idt << be_idt_nl
        << "TAO_ServerRequest &req," << be_nl
        << "void *obj," << be_nl
        << "void *servant_upcall" << be_nl
        << "ACE_ENV_ARG_DECL" << be_uidt_nl
        << ");" << be_uidt_nl << be_nl;

    // Add the dispatch method.
    *os << "virtual void _dispatch (" << be_idt << be_idt_nl
        << "TAO_ServerRequest &req," << be_nl
        << "void *_servant_upcall" << be_nl
        << "ACE_ENV_ARG_DECL" << be_uidt_nl
        << ");" << be_uidt_nl << be_nl;

    this->this_method (node);

    // The _interface_repository_id method.
    *os << be_nl
        << "virtual const char* _interface_repository_id "
        << "(void) const;";

    // Generate code for elements in the scope (e.g., operations).
    if (this->visit_scope (node) ==  -1)
      {
        ACE_ERROR_RETURN ((LM_ERROR,
                           "be_visitor_interface_sh::"
                           "visit_interface - "
                           "codegen for scope failed\n"),
                          -1);
      }

    // Generate skeletons for operations of our base classes. These
    // skeletons just cast the pointer to the appropriate type
    // before invoking the call.
    int status = 
      node->traverse_inheritance_graph (
                be_interface::gen_skel_helper, 
                os
              );

    if (status == -1)
      {
        ACE_ERROR_RETURN ((LM_ERROR,
                           "be_visitor_interface_sh::"
                           "visit_interface - "
                           "inheritance graph traversal failed\n"),
                          -1);
      }

    *os << be_uidt_nl << "};";
  } // if ! node->is_abstract ()

  be_visitor_context ctx (*this->ctx_);

  if (be_global->gen_thru_poa_collocation ()
      || be_global->gen_direct_collocation ())
    {
      ctx = *this->ctx_;
      // Generate strategized proxy broker.
      be_visitor_interface_strategized_proxy_broker_sh ispb_visitor (&ctx);

      if (node->accept (&ispb_visitor) == -1)
        {
          ACE_ERROR_RETURN ((
              LM_ERROR,
              "be_visitor_interface_sh::"
              "visit_interface - "
              "codegen for thru_poa_collocated class failed\n"
            ),
            -1
          );
        }
    }

  ctx = *this->ctx_;

  // Generate the collocated class.
  if (be_global->gen_thru_poa_collocation ())
    {
      ctx = *this->ctx_;
      ctx.state (TAO_CodeGen::TAO_INTERFACE_THRU_POA_PROXY_IMPL_SH);
      be_visitor_interface_thru_poa_proxy_impl_sh itppi_visitor (&ctx);

      if (node->accept (&itppi_visitor) == -1)
        {
          ACE_ERROR_RETURN ((LM_ERROR,
                             "be_visitor_interface_sh::"
                             "visit_interface - "
                             "codegen for thru_poa_collocated class failed\n"),
                            -1);
        }
    }

  ctx = *this->ctx_;

  if (be_global->gen_direct_collocation ())
    {
      ctx = *this->ctx_;
      ctx.state (TAO_CodeGen::TAO_INTERFACE_DIRECT_PROXY_IMPL_SH);
      be_visitor_interface_direct_proxy_impl_sh idpi_visitor (&ctx);

      if (node->accept (&idpi_visitor) == -1)
        {
          ACE_ERROR_RETURN ((
              LM_ERROR,
              "be_visitor_interface_sh::"
              "visit_interface - "
              "codegen for thru_poa_collocated class failed\n"
            ),
            -1
          );
        }
    }

  return 0;
}

int 
be_visitor_interface_sh::gen_abstract_ops_helper (
    be_interface *node,
    be_interface *base,
    TAO_OutStream *os
  )
{
  if (node == base)
    {
      return 0;
    }

  AST_Decl *d = 0;
  be_visitor_context ctx;
  ctx.stream (os);

  for (UTL_ScopeActiveIterator si (base, UTL_Scope::IK_decls);
       !si.is_done ();
       si.next ())
    {
      d = si.item ();

      if (d == 0)
        {
          ACE_ERROR_RETURN ((LM_ERROR,
                             "(%N:%l) be_visitor_interface_sh::"
                             "abstract_base_ops_helper - "
                             "bad node in this scope\n"),
                            -1);
        }

      if (d->node_type () == AST_Decl::NT_op)
        {
          UTL_ScopedName item_new_name (d->local_name (),
                                        0);

          AST_Operation *op = AST_Operation::narrow_from_decl (d);
          be_operation new_op (op->return_type (),
                               op->flags (),
                               &item_new_name,
                               op->is_local (),
                               op->is_abstract ());
          new_op.set_defined_in (node);
          be_visitor_interface::add_abstract_op_args (op,
                                                      new_op);
          be_visitor_operation_sh op_visitor (&ctx);
          op_visitor.visit_operation (&new_op);
        }
    }

  return 0;
}

void
be_visitor_interface_sh::this_method (be_interface *node)
{
  TAO_OutStream *os = this->ctx_->stream ();

  // Print out the _this() method.
  *os << "::" << node->full_name () << " *_this (" << be_idt << be_idt_nl
      << "ACE_ENV_SINGLE_ARG_DECL_WITH_DEFAULTS" << be_uidt_nl
      << ");" << be_uidt << be_nl;
}

int
be_visitor_interface_sh::generate_amh_classes (be_interface *node)
{
   if (be_global->gen_amh_classes ())
    {
      be_visitor_amh_interface_sh amh_intf (this->ctx_);
      return amh_intf.visit_interface (node);
    }

  return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -