blob: f8a6039d1dd203c4756113410f59356061af57e4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
/* -*- C++ -*- */
// $Id$
//
// ============================================================================
//
// = LIBRARY
// ORBSVCS Real-time Event Channel
//
// = FILENAME
// EC_ProxyConsumer
//
// = AUTHOR
// Carlos O'Ryan (coryan@cs.wustl.edu)
//
// = DESCRIPTION
// Implement the RtecEventChannelAdmin::ProxyPushConsumer interface,
// remember that this class is used to communicate with a
// PushSupplier, so, in effect, this is the ambassador for a
// supplier inside the event channel.
//
// = CREDITS
// Based on previous work by Tim Harrison (harrison@cs.wustl.edu)
// and other members of the DOC group.
// More details can be found in:
// http://www.cs.wustl.edu/~schmidt/oopsla.ps.gz
// http://www.cs.wustl.edu/~schmidt/JSAC-98.ps.gz
//
//
// ============================================================================
#ifndef TAO_EC_PROXYCONSUMER_H
#define TAO_EC_PROXYCONSUMER_H
#include "orbsvcs/Event/EC_Filter.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
class TAO_EC_Dispatching;
class TAO_EC_Filter_Builder;
class TAO_EC_ProxyPushConsumer : public TAO_EC_Filter
{
// = TITLE
// ProxyPushConsumer
//
// = DESCRIPTION
// Implements the ProxyPushConsumer interface, i.e. the object
// used to communicate with a particular consumer.
//
// = MEMORY MANAGMENT
// It makes a copy of the SupplierQOS and the supplier object
// reference.
// The object commits suicide when disconnect_push_consumer() is
// called.
//
// = LOCKING
// No provisions for locking, access must be serialized
// externally.
//
public:
TAO_EC_ProxyPushConsumer (TAO_EC_SupplierAdmin* supplier_admin);
// constructor...
virtual ~TAO_EC_ProxyPushConsumer (void);
// destructor...
CORBA::Boolean is_connected (void) const;
// Return 0 if no supplier is connected...
RtecEventComm::PushSupplier_ptr supplier (void) const;
// Return the consumer object reference. It returns nil() if it has
// not connected yet.
const RtecEventChannelAdmin::SupplierQOS& publications (void) const;
// The QoS (subscription) used to connect to the EC.
virtual void connected (TAO_EC_ProxyPushSupplier* supplier) = 0;
virtual void disconnected (TAO_EC_ProxyPushSupplier* supplier) = 0;
// Concrete implementations can use this methods to keep track of
// the consumers interested in this events.
// = The RtecEventChannelAdmin::ProxyPushConsumer methods...
virtual void connect_push_supplier (
RtecEventComm::PushConsumer_ptr push_consumer,
const RtecEventChannelAdmin::ConsumerQOS& qos,
CORBA::Environment &);
virtual void push (const RtecEventComm::EventSet& event,
CORBA::Environment &);
virtual void disconnect_push_consumer (CORBA::Environment &);
private:
TAO_EC_SupplierAdmin* supplier_admin_;
// The supplier admin, used for activation and memory managment.
RtecEventComm::PushSupplier_var supplier_;
// The supplier....
RtecEventChannelAdmin::SupplierQOS qos_;
// The publication and QoS information...
};
#if defined (__ACE_INLINE__)
#include "EC_ProxyConsumer.i"
#endif /* __ACE_INLINE__ */
#endif /* TAO_EC_PROXYCONSUMER_H */
|