blob: ca36e3f517e02976f10635ce52cbe02a2557b682 (
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
|
/* -*- C++ -*- */
// $Id$
// ============================================================================
//
// = LIBRARY
// gateway
//
// = FILENAME
// Concrete_Connection_Handlers.h
//
// = DESCRIPTION
// These are all the subclasses of Connection_Handler that define the
// appropriate threaded/reactive Consumer/Supplier behavior.
//
// = AUTHOR
// Doug Schmidt
//
// ============================================================================
#if !defined (CONCRETE_CONNECTION_HANDLER)
#define CONCRETE_CONNECTION_HANDLER
#include "Connection_Handler.h"
class Supplier_Handler : public Connection_Handler
{
// = TITLE
// Handles reception of Events from Suppliers.
//
// = DESCRIPTION
// Performs framing and error checking on Events. Intended to
// run reactively, i.e., in one thread of control using a
// Reactor for demuxing and dispatching.
public:
// = Initialization method.
Supplier_Handler (const Connection_Config_Info &);
protected:
// = All the following methods are upcalls, so they can be protected.
virtual int handle_input (ACE_HANDLE = ACE_INVALID_HANDLE);
// Receive and process peer events.
virtual int recv (ACE_Message_Block *&);
// Receive an event from a Supplier.
int process (ACE_Message_Block *event);
// This delegates to the <Event_Channel> to do the actual
// processing. Typically, it forwards the <event> to its
// appropriate Consumer.
ACE_Message_Block *msg_frag_;
// Keep track of event fragment to handle non-blocking recv's from
// Suppliers.
};
class Consumer_Handler : public Connection_Handler
{
// = TITLE
// Handles transmission of events to Consumers.
//
// = DESCRIPTION
// Performs queueing and error checking. Intended to run
// reactively, i.e., in one thread of control using a Reactor
// for demuxing and dispatching. Also uses a Reactor to handle
// flow controlled output connections.
public:
// = Initialization method.
Consumer_Handler (const Connection_Config_Info &);
virtual int put (ACE_Message_Block *event,
ACE_Time_Value * = 0);
// Send an event to a Consumer (may be queued if necessary).
protected:
virtual int handle_output (ACE_HANDLE);
// Finish sending event when flow control conditions abate.
int nonblk_put (ACE_Message_Block *mb);
// Perform a non-blocking put().
virtual ssize_t send (ACE_Message_Block *);
// Send an event to a Consumer.
virtual int handle_input (ACE_HANDLE);
// Receive and process shutdowns from a Consumer.
};
class Thr_Consumer_Handler : public Consumer_Handler
{
// = TITLE
// Runs each <Consumer_Handler> in a separate thread.
public:
Thr_Consumer_Handler (const Connection_Config_Info &);
virtual int open (void *);
// Initialize the threaded Consumer_Handler object and spawn a new
// thread.
virtual int put (ACE_Message_Block *, ACE_Time_Value * = 0);
// Send a message to a peer.
protected:
virtual int handle_input (ACE_HANDLE);
// Called when Peer shutdown unexpectedly.
virtual int svc (void);
// Transmit peer messages.
};
class Thr_Supplier_Handler : public Supplier_Handler
{
// = TITLE
// Runs each <Supplier_Handler> in a separate thread.
public:
Thr_Supplier_Handler (const Connection_Config_Info &pci);
virtual int open (void *);
// Initialize the object and spawn a new thread.
protected:
virtual int svc (void);
// Transmit peer messages.
};
#endif /* CONCRETE_CONNECTION_HANDLER */
|