blob: f7282864f734ee57111b70b15be5e86ecd694f45 (
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
|
//=============================================================================
/**
* @file Reactor_Performance_Test.h
*
* This file includes template class definitions for the
* Reactor_Performance_Test.cpp program. This class gets its own
* header file to work around AIX C++ compiler "features" related
* to template instantiation...
*
* @author Irfan Pyarali <irfan@cs.wustl.edu> and Steve Huston <shuston@riverace.com>
*/
//=============================================================================
#ifndef ACE_TESTS_REACTOR_PERFORMANCE_TEST_H
#define ACE_TESTS_REACTOR_PERFORMANCE_TEST_H
#include "ace/SOCK_Stream.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#include "ace/Svc_Handler.h"
/**
* @class Read_Handler
*
* @brief Simple class for reading in the data
*/
class Read_Handler : public ACE_Svc_Handler<ACE_SOCK_STREAM, ACE_SYNCH>
{
public:
static void set_countdown (int nconnections);
/// The Svc_Handler callbacks.
virtual int open (void *);
virtual int handle_input (ACE_HANDLE h);
virtual int handle_close (ACE_HANDLE handle,
ACE_Reactor_Mask close_mask);
private:
/// How many connections are we waiting for.
static int waiting_;
};
/**
* @class Write_Handler
*
* @brief This Svc_Handler simply connects to a server and sends some
* output to it. Its purpose is to feed the test.
*/
class Write_Handler : public ACE_Svc_Handler<ACE_SOCK_STREAM, ACE_SYNCH>
{
public:
virtual int open (void *);
virtual int send_data (void);
};
#endif /* ACE_TESTS_REACTOR_PERFORMANCE_TEST_H */
|