TAO_RTEvent  2.1.2
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Public Member Functions | Protected Types | Protected Member Functions | Protected Attributes
TAO_EC_Event_Channel_Base Class Reference

The RtecEventChannelAdmin::EventChannel implementation. More...

#include <EC_Event_Channel_Base.h>

Inheritance diagram for TAO_EC_Event_Channel_Base:
Inheritance graph
[legend]
Collaboration diagram for TAO_EC_Event_Channel_Base:
Collaboration graph
[legend]

List of all members.

Public Member Functions

virtual ~TAO_EC_Event_Channel_Base (void)
 destructor
virtual void activate (void)
virtual void shutdown (void)
virtual void for_each_consumer (TAO_ESF_Worker< TAO_EC_ProxyPushSupplier > *worker)
virtual void for_each_supplier (TAO_ESF_Worker< TAO_EC_ProxyPushConsumer > *worker)
TAO_EC_Dispatchingdispatching (void) const
 Access the dispatching module....
TAO_EC_Filter_Builderfilter_builder (void) const
 Access the filter builder....
TAO_EC_Supplier_Filter_Buildersupplier_filter_builder (void) const
 Access the filter builder....
TAO_EC_ConsumerAdminconsumer_admin (void) const
TAO_EC_SupplierAdminsupplier_admin (void) const
TAO_EC_Timeout_Generatortimeout_generator (void) const
 Access the timer module...
TAO_EC_Scheduling_Strategyscheduling_strategy (void) const
 Access the scheduling strategy.
TAO_EC_ConsumerControlconsumer_control (void) const
 Access the client control strategies.
TAO_EC_SupplierControlsupplier_control (void) const
void create_proxy (TAO_EC_ProxyPushSupplier *&)
 Create and destroy a ProxyPushSupplier.
void destroy_proxy (TAO_EC_ProxyPushSupplier *)
void create_proxy (TAO_EC_ProxyPushConsumer *&)
 Create and destroy a ProxyPushConsumer.
void destroy_proxy (TAO_EC_ProxyPushConsumer *)
void create_proxy_collection (TAO_EC_ProxyPushSupplier_Collection *&)
void destroy_proxy_collection (TAO_EC_ProxyPushSupplier_Collection *)
void create_proxy_collection (TAO_EC_ProxyPushConsumer_Collection *&)
void destroy_proxy_collection (TAO_EC_ProxyPushConsumer_Collection *)
PortableServer::POA_ptr supplier_poa (void)
 Access the supplier and consumer POAs from the factory.
PortableServer::POA_ptr consumer_poa (void)
ACE_Lockcreate_consumer_lock (void)
void destroy_consumer_lock (ACE_Lock *)
ACE_Lockcreate_supplier_lock (void)
void destroy_supplier_lock (ACE_Lock *)
virtual void connected (TAO_EC_ProxyPushConsumer *)
virtual void reconnected (TAO_EC_ProxyPushConsumer *)
virtual void disconnected (TAO_EC_ProxyPushConsumer *)
virtual void connected (TAO_EC_ProxyPushSupplier *)
virtual void reconnected (TAO_EC_ProxyPushSupplier *)
virtual void disconnected (TAO_EC_ProxyPushSupplier *)
int consumer_reconnect (void) const
 Can the consumers reconnect to the EC?
int supplier_reconnect (void) const
 Can the suppliers reconnect to the EC?
int disconnect_callbacks (void) const
CORBA::Object_ptr scheduler (void)
 Obtain the scheduler, the user must release.
virtual
RtecEventChannelAdmin::ConsumerAdmin_ptr 
for_consumers (void)
virtual
RtecEventChannelAdmin::SupplierAdmin_ptr 
for_suppliers (void)
virtual void destroy (void)
 Commit suicide.
virtual
RtecEventChannelAdmin::Observer_Handle 
append_observer (RtecEventChannelAdmin::Observer_ptr)
virtual void remove_observer (RtecEventChannelAdmin::Observer_Handle)
int destroyed (void)
 Return 1 if the event channel is already destroyed.

Protected Types

enum  {
  EC_S_IDLE, EC_S_ACTIVATING, EC_S_ACTIVE, EC_S_DESTROYING,
  EC_S_DESTROYED
}
 Flag to track the status of the event channel. More...

Protected Member Functions

 TAO_EC_Event_Channel_Base (const TAO_EC_Event_Channel_Attributes &attributes, TAO_EC_Factory *factory=0, int own_factory=0)
TAO_EC_Factoryfactory (void) const
void factory (TAO_EC_Factory *factory, int own_factory=0)
void create_strategies (void)
void deactivate_supplier_admin (void)
void deactivate_consumer_admin (void)

Protected Attributes

PortableServer::POA_var supplier_poa_
PortableServer::POA_var consumer_poa_
TAO_EC_Factoryfactory_
int own_factory_
 Flag that indicates if we own the factory.
TAO_EC_Dispatchingdispatching_
 The dispatching "module".
TAO_EC_Filter_Builderfilter_builder_
 The filter builder.
TAO_EC_Supplier_Filter_Buildersupplier_filter_builder_
 The filter builder for suppliers.
TAO_EC_ConsumerAdminconsumer_admin_
 The ConsumerAdmin implementation.
TAO_EC_SupplierAdminsupplier_admin_
 The SupplierAdmin implementation.
TAO_EC_Timeout_Generatortimeout_generator_
 The timeout generator.
TAO_EC_ObserverStrategyobserver_strategy_
 The observer strategy.
CORBA::Object_var scheduler_
 The scheduler (may be nil)
TAO_EC_Scheduling_Strategyscheduling_strategy_
 The scheduling strategy.
int consumer_reconnect_
 Consumer reconnection flags.
int supplier_reconnect_
 Supplier reconnection flags.
int disconnect_callbacks_
 If not zero we send callbacks when a proxy is disconnected.
TAO_EC_ConsumerControlconsumer_control_
 Strategies to disconnect misbehaving or destroyed consumers.
TAO_EC_SupplierControlsupplier_control_
 Strategies to disconnect misbehaving or destroyed suppliers.
TAO_SYNCH_MUTEX mutex_
 Mutex to protect the internal state.
int status_

Detailed Description

The RtecEventChannelAdmin::EventChannel implementation.

This class is the Mediator between all the classes in the EC implementation, its main task is to redirect the messages to the right components, to hold and manage the lifetime of the long lived objects (Timer_Module, SupplierAdmin, ConsumerAdmin and Dispatching) and to provide a simpler interface to the EC_Factory.


Member Enumeration Documentation

anonymous enum
protected

Flag to track the status of the event channel.

Enumerator:
EC_S_IDLE 
EC_S_ACTIVATING 
EC_S_ACTIVE 
EC_S_DESTROYING 
EC_S_DESTROYED 

Constructor & Destructor Documentation

destructor

TAO_EC_Event_Channel_Base::TAO_EC_Event_Channel_Base ( const TAO_EC_Event_Channel_Attributes attributes,
TAO_EC_Factory factory = 0,
int  own_factory = 0 
)
protected

Constructor If own_factory is not 0 it assumes ownership of the factory. If the factory is nil it uses the Service_Configurator to load the Factory, if not found it uses TAO_EC_Default_Resource_Factory


Member Function Documentation

void TAO_EC_Event_Channel_Base::activate ( void  )
virtual

Start the internal threads (if any), etc. After this call the EC can be used.

RtecEventChannelAdmin::Observer_Handle TAO_EC_Event_Channel_Base::append_observer ( RtecEventChannelAdmin::Observer_ptr  observer)
virtual

Used to inform the EC that a Consumer has connected or disconnected from it.

Used to inform the EC that a Supplier has connected or disconnected from it.

Access the consumer admin implementation, useful for controlling the activation...

Access the client control strategies.

Can the consumers reconnect to the EC?

Locking strategies for the ProxyPushConsumer and ProxyPushSupplier objects

Create and destroy a ProxyPushSupplier.

Create and destroy a ProxyPushConsumer.

Create and destroy a the collections used to store ProxyPushSuppliers

Create and destroy a the collections used to store ProxyPushConsumers

Create all strategies

Helpers. Deactivate admins from their POAs, ignoring any CORBA exceptions.

Helpers. Deactivate admins from their POAs, ignoring any CORBA exceptions.

void TAO_EC_Event_Channel_Base::destroy ( void  )
virtual

Commit suicide.

Return 1 if the event channel is already destroyed.

Should we send callback disconnect messages when a proxy is disconnected by the client

Access the dispatching module....

TAO_EC_Factory * TAO_EC_Event_Channel_Base::factory ( void  ) const
protected

Get the factory.

void TAO_EC_Event_Channel_Base::factory ( TAO_EC_Factory factory,
int  own_factory = 0 
)
protected

Set the factory, if own_factory is not 0 it assumes ownership of the factory.

Access the filter builder....

RtecEventChannelAdmin::ConsumerAdmin_ptr TAO_EC_Event_Channel_Base::for_consumers ( void  )
virtual

The default implementation is: this->consumer_admin ()->_this ();

RtecEventChannelAdmin::SupplierAdmin_ptr TAO_EC_Event_Channel_Base::for_suppliers ( void  )
virtual

The default implementation is: this->supplier_admin ()->_this ();

Obtain the scheduler, the user must release.

Access the scheduling strategy.

void TAO_EC_Event_Channel_Base::shutdown ( void  )
virtual

Shutdown any internal threads, cleanup all the internal structures, flush all the messages, etc.

Access the supplier admin implementation, useful for controlling the activation...

Access the filter builder....

Access the supplier and consumer POAs from the factory.

Can the suppliers reconnect to the EC?

Access the timer module...


Member Data Documentation

The ConsumerAdmin implementation.

Strategies to disconnect misbehaving or destroyed consumers.

Consumer reconnection flags.

If not zero we send callbacks when a proxy is disconnected.

The dispatching "module".

This is the abstract factory that creates all the objects that compose an event channel, the event channel simply acts as a Mediator among them.

The filter builder.

Mutex to protect the internal state.

The observer strategy.

Flag that indicates if we own the factory.

The scheduler (may be nil)

The scheduling strategy.

The SupplierAdmin implementation.

Strategies to disconnect misbehaving or destroyed suppliers.

The filter builder for suppliers.

The POAs used to activate "supplier-side" and "consumer-side" objects.

Supplier reconnection flags.

The timeout generator.


The documentation for this class was generated from the following files: