diff options
Diffstat (limited to 'TAO/TAO_IDL/be/be_visitor_interface/remote_proxy_broker_ch.cpp')
-rw-r--r-- | TAO/TAO_IDL/be/be_visitor_interface/remote_proxy_broker_ch.cpp | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/TAO/TAO_IDL/be/be_visitor_interface/remote_proxy_broker_ch.cpp b/TAO/TAO_IDL/be/be_visitor_interface/remote_proxy_broker_ch.cpp new file mode 100644 index 00000000000..fca454e14bf --- /dev/null +++ b/TAO/TAO_IDL/be/be_visitor_interface/remote_proxy_broker_ch.cpp @@ -0,0 +1,94 @@ +// +// $Id$ +// + +ACE_RCSID (be_visitor_interface, + be_visitor_interface_remote_proxy_broker_ch, + "$Id$") + +be_visitor_interface_remote_proxy_broker_ch:: +be_visitor_interface_remote_proxy_broker_ch (be_visitor_context *ctx) + : be_visitor_interface (ctx) +{ + // No-Op. +} + + +be_visitor_interface_remote_proxy_broker_ch:: +~be_visitor_interface_remote_proxy_broker_ch (void) +{ + // No-Op. +} + +int +be_visitor_interface_remote_proxy_broker_ch::visit_interface ( + be_interface *node + ) +{ + TAO_OutStream *os = this->ctx_->stream (); + + // Generate the class declaration. + os->indent (); + + *os << be_nl + << "///////////////////////////////////////////////////////////////////////" + << be_nl + << "// Remote Proxy Broker Declaration " << be_nl + << "//" << be_nl << be_nl; + + *os << "// TAO_IDL - Generated from" << be_nl + << "// " << __FILE__ << ":" << __LINE__ << be_nl << be_nl; + + *os << "class " << be_global->stub_export_macro () << " " + << node->remote_proxy_broker_name () << be_idt_nl + << ": public virtual " + << node->base_proxy_broker_name () << be_uidt_nl + << "{" << be_nl + << "public: " << be_idt_nl; + + // Constructor + *os << node->remote_proxy_broker_name () << " (void);" << be_nl << be_nl; + + // Destructor + *os << "virtual ~" << node->remote_proxy_broker_name () << " (void);" + << be_nl << be_nl; + + // Accessor Method + *os << "virtual " << node->base_proxy_impl_name () << " &" + << "select_proxy (" + << be_idt << be_idt_nl; + + *os << node->local_name () << " *object" << be_uidt_nl + << ");" << be_uidt_nl << be_uidt_nl; + + *os << "private:" << be_idt_nl + << node->remote_proxy_impl_name () << " remote_proxy_impl_;" + << be_uidt_nl << be_nl; + + *os << "public:" << be_idt_nl; + + // Factory Member Function declaration. + *os << "// This member function is used to get an handle to the " + << "unique instance" << be_nl + << "// of the Remote Proxy Broker that is available for a given" + << be_nl + << "// interface." << be_nl + << "static " << node->remote_proxy_broker_name () + << " *the" << node->remote_proxy_broker_name () + << " (void);" << be_uidt_nl; + + *os << "};" << be_nl << be_nl; + + *os << "//" << be_nl + << "// End Remote Proxy Broker Declaration " << be_nl + << "///////////////////////////////////////////////////////////////////////"; + + return 0; +} + +int be_visitor_interface_remote_proxy_broker_ch::visit_component ( + be_component *node + ) +{ + return this->visit_interface (node); +} |