summaryrefslogtreecommitdiff
path: root/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp')
-rw-r--r--TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp72
1 files changed, 72 insertions, 0 deletions
diff --git a/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp b/TAO/TAO_IDL/be/be_visitor_interface/proxy_impls_ch.cpp
new file mode 100644
index 00000000000..ae043a1c56e
--- /dev/null
+++ b/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);
+}