blob: b1adfc0b0bc396a4899ce4adf6048e9704caf2e1 (
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
|
/* -*- C++ -*- */
// $Id$
// ================================================================
//
// = LIBRARY
// TAO services
//
// = FILENAME
// ProxyPushSupplier_i
//
// = AUTHOR
// Pradeep Gore <pradeep@cs.wustl.edu>
//
// = DESCRIPTION
// This has the implementation of the
// CosEventChannelAdmin::ProxyPushSupplier interface.
//
// ================================================================
#ifndef _PROXYPUSHSUPPLIER_H
#define _PROXYPUSHSUPPLIER_H
#include /**/ "ace/pre.h"
#include "orbsvcs/RtecEventChannelAdminC.h"
#include "orbsvcs/CosEventChannelAdminC.h"
#include "rtec_cosec_export.h"
#if defined(_MSC_VER)
#if (_MSC_VER >= 1200)
#pragma warning(push)
#endif /* _MSC_VER >= 1200 */
#pragma warning(disable:4250)
#endif /* _MSC_VER */
class TAO_CosEC_PushConsumerWrapper;
class TAO_RTEC_COSEC_Export TAO_CosEC_ProxyPushSupplier_i :
public POA_CosEventChannelAdmin::ProxyPushSupplier,
public virtual PortableServer::RefCountServantBase
{
// = TITLE
// class ProxyPushSupplier-i implements the ProxyPushConsumer interface.
//
// = DESCRIPTION
// This implementation of the ProxyPushSupplier uses the
// RtecEventChannelAdmin::ProxyPushSupplier.
public:
// = Initialization and termination methods.
TAO_CosEC_ProxyPushSupplier_i (const RtecEventChannelAdmin::ConsumerQOS &qos,
RtecEventChannelAdmin::ProxyPushSupplier_ptr pps);
// Constructor.
~TAO_CosEC_ProxyPushSupplier_i (void);
// Destructor.
virtual void disconnect_push_supplier (ACE_ENV_SINGLE_ARG_DECL)
ACE_THROW_SPEC ((CORBA::SystemException));
// Ends the event communication and disposes this object.
virtual void connect_push_consumer(CosEventComm::PushConsumer_ptr push_consumer
ACE_ENV_ARG_DECL)
ACE_THROW_SPEC ((CORBA::SystemException,
CosEventChannelAdmin::AlreadyConnected,
CosEventChannelAdmin::TypeError));
// Connects the <push_consumer> to the Event Channel.
private:
int connected (void);
// Returns 0 if a push_consumer is already connected to this
// ProxyPushSupplier, otherwise it returns a 1.
const RtecEventChannelAdmin::ConsumerQOS &qos_;
// The ConsumerQOS specified by the user of this class.
RtecEventChannelAdmin::ProxyPushSupplier_var pps_;
// The Rtec ProxyPushSupplier specified by the user of this class.
TAO_CosEC_PushConsumerWrapper *wrapper_;
// The Rtec PushConsumer wrapper used by the Rtec ProxyPushSupplier.
};
#if defined(_MSC_VER) && (_MSC_VER >= 1200)
#pragma warning(pop)
#endif /* _MSC_VER */
#include /**/ "ace/post.h"
#endif /* _PROXYPUSHSUPPLIER_H */
|