summaryrefslogtreecommitdiff
path: root/TAO/TAO_IDL/be/be_visitor_interface/remote_proxy_broker_ch.cpp
diff options
context:
space:
mode:
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.cpp94
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);
+}