summaryrefslogtreecommitdiff
path: root/ACE/Kokyu/Kokyu.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/Kokyu/Kokyu.cpp')
-rw-r--r--ACE/Kokyu/Kokyu.cpp55
1 files changed, 55 insertions, 0 deletions
diff --git a/ACE/Kokyu/Kokyu.cpp b/ACE/Kokyu/Kokyu.cpp
new file mode 100644
index 00000000000..e447f731493
--- /dev/null
+++ b/ACE/Kokyu/Kokyu.cpp
@@ -0,0 +1,55 @@
+// $Id$
+
+#include "Kokyu.h"
+
+#include "Default_Dispatcher_Impl.h"
+
+#if ! defined (__ACE_INLINE__)
+#include "Kokyu.i"
+#endif /* __ACE_INLINE__ */
+
+ACE_RCSID(Kokyu, Kokyu, "$Id$")
+
+namespace Kokyu
+{
+
+int Dispatcher::dispatch (const Dispatch_Command* cmd, const QoSDescriptor& qos)
+{
+ return dispatcher_impl_->dispatch (cmd, qos);
+}
+
+int Dispatcher::shutdown ()
+{
+ return dispatcher_impl_->shutdown ();
+}
+
+int Dispatcher::activate ()
+{
+ return dispatcher_impl_->activate ();
+}
+
+void Dispatcher::implementation (Dispatcher_Impl* impl)
+{
+ auto_ptr<Dispatcher_Impl> tmp_impl (impl);
+ dispatcher_impl_ = tmp_impl;
+
+ //I couldn't use reset because MSVC++ auto_ptr does not have reset method.
+ //So in configurations where the auto_ptr maps to the std::auto_ptr instead
+ //of ACE auto_ptr, this would be a problem.
+ //dispatcher_impl_.reset (impl);
+}
+
+Dispatcher*
+Dispatcher_Factory::
+create_dispatcher(const Dispatcher_Attributes& attrs)
+{
+ Dispatcher* disp;
+ Dispatcher_Impl* tmp;
+ ACE_NEW_RETURN (tmp, Default_Dispatcher_Impl, 0);
+ ACE_NEW_RETURN (disp, Dispatcher, 0);
+ disp->implementation (tmp);
+ tmp->init (attrs);
+ return disp;
+}
+
+}