blob: 16dcdf22acf93d6cd3ac859736c459d44d6cf0e7 (
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
|
/* -*- C++ -*- */
// $Id$
//
// ============================================================================
//
// = LIBRARY
// ORBSVCS Real-time Event Channel testsuite
//
// = FILENAME
// Counting_Supplier
//
// = AUTHOR
// Carlos O'Ryan (coryan@cs.wustl.edu)
//
// ============================================================================
#ifndef EC_COUNTING_SUPPLIER_H
#define EC_COUNTING_SUPPLIER_H
#include "ectest_export.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#include "orbsvcs/Channel_Clients.h"
#include "orbsvcs/RtecEventChannelAdminC.h"
#include "ace/Task.h"
class EC_Test_Export EC_Counting_Supplier : public POA_RtecEventComm::PushSupplier
{
// = TITLE
// Simple supplier object
//
// = DESCRIPTION
// This class is a supplier of events.
//
public:
EC_Counting_Supplier (void);
// Constructor
// = The RtecEventComm::PushSupplier methods
void activate (RtecEventChannelAdmin::ConsumerAdmin_ptr consumer_admin,
int period
ACE_ENV_ARG_DECL);
void deactivate (ACE_ENV_SINGLE_ARG_DECL);
// Connect as a consumer to receive a TIMEOUT every <period>
// milliseconds.
// The class pushes an event (in its supplier role) every time it
// receives the timeout.
void connect (RtecEventChannelAdmin::SupplierAdmin_ptr supplier_admin,
int published_source,
int published_type,
int event_source,
int event_type
ACE_ENV_ARG_DECL);
void connect (RtecEventChannelAdmin::SupplierAdmin_ptr supplier_admin,
const RtecEventChannelAdmin::SupplierQOS &qos
ACE_ENV_ARG_DECL);
void disconnect (ACE_ENV_SINGLE_ARG_DECL);
// Simple connect/disconnect methods..
void push (const RtecEventComm::EventSet& events
ACE_ENV_ARG_DECL)
ACE_THROW_SPEC ((CORBA::SystemException));
void disconnect_push_consumer (ACE_ENV_SINGLE_ARG_DECL_NOT_USED)
ACE_THROW_SPEC ((CORBA::SystemException));
// The Consumer side methods.
virtual void disconnect_push_supplier (ACE_ENV_SINGLE_ARG_DECL_NOT_USED)
ACE_THROW_SPEC ((CORBA::SystemException));
// The skeleton methods.
CORBA::ULong event_count;
// Count the number of events sent
CORBA::ULong disconnect_count;
// Count the number of disconnect_push_supplier calls
private:
ACE_PushConsumer_Adapter<EC_Counting_Supplier> consumer_adapter_;
// Adapter...
RtecEventChannelAdmin::ProxyPushSupplier_var supplier_proxy_;
// The adapter proxy...
RtecEventChannelAdmin::ProxyPushConsumer_var consumer_proxy_;
// Our proxy
int event_source_;
// The event source
int event_type_;
// The event type
};
class EC_Test_Export EC_Counting_Supplier_Task : public ACE_Task_Base
{
public:
EC_Counting_Supplier_Task (EC_Counting_Supplier *supplier);
// Create the task...
// = Check the ACE_Task_Base documentation.
int svc (void);
void stop (void);
CORBA::ULong push_count (void);
void run (ACE_ENV_SINGLE_ARG_DECL);
// Run a single iteration of the test
private:
EC_Counting_Supplier *supplier_;
// The supplier we are turning into an active object
RtecEventComm::EventSet event_;
// The event we push through the supplier
int stop_flag_;
// Set to 1 when the test must stop
CORBA::ULong push_count_;
// Count the number of push() calls
TAO_SYNCH_MUTEX lock_;
};
#endif /* ECT_SUPPLIER_H */
|