diff options
Diffstat (limited to 'modules/CIAO/connectors/dds4ccm/examples/Shapes/Sender/Shapes_Sender_exec.h')
-rw-r--r-- | modules/CIAO/connectors/dds4ccm/examples/Shapes/Sender/Shapes_Sender_exec.h | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/modules/CIAO/connectors/dds4ccm/examples/Shapes/Sender/Shapes_Sender_exec.h b/modules/CIAO/connectors/dds4ccm/examples/Shapes/Sender/Shapes_Sender_exec.h new file mode 100644 index 00000000000..9fa93f905a4 --- /dev/null +++ b/modules/CIAO/connectors/dds4ccm/examples/Shapes/Sender/Shapes_Sender_exec.h @@ -0,0 +1,108 @@ +// -*- C++ -*- +// $Id$ + +#ifndef CIAO_SENDER_EXEC_H_ +#define CIAO_SENDER_EXEC_H_ + +#include "Shapes_SenderEC.h" + +#include /**/ "Sender_exec_export.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +#include "tao/LocalObject.h" +#include "ace/Task.h" +#include "ace/Reactor.h" + +namespace CIAO_Shapes_Sender_Impl +{ + class Sender_exec_i; + + //============================================================ + // pulse_Generator + //============================================================ + class pulse_Generator : public ACE_Event_Handler + { + public: + pulse_Generator (Sender_exec_i &callback); + + virtual ~pulse_Generator (); + + virtual int handle_timeout (const ACE_Time_Value &tv, + const void *arg); + private: + Sender_exec_i &pulse_callback_; + }; + + //============================================================ + // Sender_exec_i + //============================================================ + class Sender_exec_i + : public virtual Sender_Exec, + public virtual ::CORBA::LocalObject + { + public: + Sender_exec_i (void); + virtual ~Sender_exec_i (void); + + virtual ::CORBA::ULong rate (void); + + virtual void rate (::CORBA::ULong rate); + + virtual ::CORBA::UShort max_x (void); + + virtual void max_x (::CORBA::UShort max_x); + + virtual ::CORBA::UShort max_y (void); + + virtual void max_y (::CORBA::UShort max_y); + + virtual ::CORBA::UShort max_size (void); + + virtual void max_size (::CORBA::UShort max_size); + + virtual void resize_shape (::CORBA::Boolean resize); + + virtual ::CORBA::Boolean resize_shape (void); + + virtual void set_session_context (::Components::SessionContext_ptr ctx); + + virtual void configuration_complete (void); + + virtual void ccm_activate (void); + virtual void ccm_passivate (void); + virtual void ccm_remove (void); + + void tick (); + + private: + void start (void); + void stop (void); + + Shapes::ShapeTypeConn::Writer_var writer_; + + pulse_Generator * ticker_; + ::Shapes::CCM_Sender_Context_var context_; + CORBA::ULong rate_; + CORBA::UShort max_x_; + CORBA::UShort max_y_; + CORBA::UShort max_size_; + CORBA::Boolean resize_; + + bool x_increasing_; + bool y_increasing_; + bool size_increasing_; + + ShapeType* square_; + + ::DDS::InstanceHandle_t instance_handle_; + }; + + extern "C" SENDER_EXEC_Export ::Components::EnterpriseComponent_ptr + create_Shape_Sender_Impl (void); +} + +#endif /* ifndef */ + |