diff options
Diffstat (limited to 'ACE/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp')
-rw-r--r-- | ACE/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/ACE/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp b/ACE/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp new file mode 100644 index 00000000000..ae043a1c56e --- /dev/null +++ b/ACE/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp @@ -0,0 +1,72 @@ +// +// $Id$ +// + +ACE_RCSID (be_visitor_interface, + base_proxy_broker_impl_ch, + "$Id$") + +be_visitor_interface_proxy_impls_ch::be_visitor_interface_proxy_impls_ch ( + be_visitor_context *ctx + ) + : be_visitor_interface (ctx) +{ + // No-Op. +} + + +be_visitor_interface_proxy_impls_ch::~be_visitor_interface_proxy_impls_ch ( + void + ) +{ + // No-Op. +} + +int +be_visitor_interface_proxy_impls_ch::visit_interface (be_interface *node) +{ + TAO_OutStream *os = this->ctx_->stream (); + + // Generate Guards. + *os << "// The Proxy Implementations are used by each interface to" + << be_nl + << "// perform a call. Each different implementation encapsulates" + << be_nl + << "// an invocation logic." << be_nl << be_nl; + + // Code Generation for the proxy imlpementations base class. + be_visitor_context ctx (*this->ctx_); + ctx.state (TAO_CodeGen::TAO_INTERFACE_BASE_PROXY_IMPL_CH); + be_visitor_interface_base_proxy_impl_ch bpi_visitor (&ctx); + + if (node->accept (&bpi_visitor) == -1) + { + ACE_ERROR_RETURN ((LM_ERROR, + "be_visitor_interface_proxy_impls_ch::" + "visit_interface - " + "codegen for Base Proxy Impl. class failed\n"), + -1); + } + + ctx = *this->ctx_; + ctx.state (TAO_CodeGen::TAO_INTERFACE_REMOTE_PROXY_IMPL_CH); + be_visitor_interface_remote_proxy_impl_ch rpi_visitor (&ctx); + + if (node->accept (&rpi_visitor) == -1) + { + ACE_ERROR_RETURN ((LM_ERROR, + "be_visitor_interface_proxy_impls_ch::" + "visit_interface - " + "codegen for Remote Proxy Broker class failed\n"), + -1); + } + + return 0; +} + +int be_visitor_interface_proxy_impls_ch::visit_component ( + be_component *node + ) +{ + return this->visit_interface (node); +} |