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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
|
// -*- C++ -*-
//=============================================================================
/**
* @file Pluggable_Messaging.h
*
* $Id$
*
* Interface for the TAO pluggable messaging framework.
*
*
* @author Balachandran Natarajan <bala@cs.wustl.edu>
*/
//=============================================================================
#ifndef TAO_PLUGGABLE_MESSAGING_H
#define TAO_PLUGGABLE_MESSAGING_H
#include /**/ "ace/pre.h"
#include /**/ "tao/TAO_Export.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#include "tao/Basic_Types.h"
ACE_BEGIN_VERSIONED_NAMESPACE_DECL
class ACE_Time_Value;
ACE_END_VERSIONED_NAMESPACE_DECL
TAO_BEGIN_VERSIONED_NAMESPACE_DECL
namespace CORBA
{
class Exception;
}
class TAO_Target_Specification;
class TAO_Pluggable_Reply_Params;
class TAO_Pluggable_Reply_Params_Base;
class TAO_Transport;
class TAO_Operation_Details;
class TAO_Target_Specification;
class TAO_OutputCDR;
class TAO_Queued_Data;
class TAO_GIOP_Fragmentation_Strategy;
// @@ The more I think I about this class, I feel that this class need
// not be a ABC as it is now. Instead we have these options
// (1) Parametrize this class with the "Messaging Object". Then the
// implementations can just redirect the request to the class
// that it has been specialised with
// (2) Use a bridge pattern here ie. the interface exposed by this
// class will redirect the request to the implementation which
// would be "right messaging" object.
// Both of them feasible. If we are not going like templates much, (2)
// is seems to be a better option.
// I am going to take a closer look on this after my MS defense -
// Bala
/**
* @class TAO_Pluggable_Messaging
*
* @brief Generic definitions Messaging class.
*
* This interface tries to define generic methods that could be
* different messaging protocols
*/
class TAO_Export TAO_Pluggable_Messaging
{
public:
/// Dtor
virtual ~TAO_Pluggable_Messaging (void);
/// Write the RequestHeader in to the @a cdr stream. The underlying
/// implementation of the mesaging should do the right thing.
virtual int generate_request_header (
TAO_Operation_Details &op,
TAO_Target_Specification &spec,
TAO_OutputCDR &cdr) = 0;
/// Write the RequestHeader in to the @a cdr stream.
virtual int generate_locate_request_header (
TAO_Operation_Details &op,
TAO_Target_Specification &spec,
TAO_OutputCDR &cdr) = 0;
/**
* Write the reply header
* The reply header is a part of any messaging protocol. The
* messaging protocol implementation would implement the way the
* reply header is written.
*/
virtual int generate_reply_header (
TAO_OutputCDR &cdr,
TAO_Pluggable_Reply_Params_Base ¶ms) = 0;
/**
* Write the locate reply header
* The locate reply header is a part of any messaging protocol. The
* messaging protocol implementation would implement the way the
* locate reply header is written.
*/
virtual int generate_locate_reply_header (
TAO_OutputCDR &cdr,
TAO_Pluggable_Reply_Params_Base ¶ms) = 0;
virtual int generate_fragment_header (TAO_OutputCDR & cdr,
CORBA::ULong request_id) = 0;
/// Format the message in the @a cdr. May not be needed in
/// general.
virtual int format_message (TAO_OutputCDR &cdr) = 0;
/// Do any initialisations that may be needed.
virtual void init (CORBA::Octet major,
CORBA::Octet minor) = 0;
/// Parse the details of the next message from the @a incoming
/// and initializes attributes of @a qd. Returns 0 if the message
/// header could not be parsed completely, returns a 1 if the message
/// header could be parsed completely and returns -1 on error. As the
/// parsed data is stored directly in @a qd, no state must be stored
/// in instance of implementation.
virtual int parse_next_message (ACE_Message_Block &incoming,
TAO_Queued_Data &qd, /* out */
size_t &mesg_length) = 0; /* out */
/// Extract the details of the next message from the @a incoming
/// through @a qd. Returns 0 if the message header could not be
/// parsed completely, returns a 1 if the message header could be
/// parsed completely and returns -1 on error.
virtual int extract_next_message (ACE_Message_Block &incoming,
TAO_Queued_Data *&qd) = 0;
/// Check whether the node @a qd needs consolidation from @a incoming,
/// @r 0 on success, -1 on error
virtual int consolidate_node (TAO_Queued_Data *qd,
ACE_Message_Block &incoming) = 0;
/// Parse the request message, make an upcall and send the reply back
/// to the "request initiator"
virtual int process_request_message (TAO_Transport *transport,
TAO_Queued_Data *qd) = 0;
/// Parse the reply message that we received and return the reply
/// information through @a reply_info
virtual int process_reply_message (
TAO_Pluggable_Reply_Params &reply_info,
TAO_Queued_Data *qd) = 0;
/// Generate a reply message with the exception @a ex.
virtual int generate_exception_reply (
TAO_OutputCDR &cdr,
TAO_Pluggable_Reply_Params_Base ¶ms,
CORBA::Exception &ex) = 0;
/// Is the messaging object ready for processing BiDirectional
/// request/response?
virtual int is_ready_for_bidirectional (TAO_OutputCDR &msg) = 0;
/// Reset the messaging the object
virtual void reset (void) = 0;
/// Header length
virtual size_t header_length (void) const = 0;
/// Fragment header length
virtual size_t fragment_header_length (CORBA::Octet major,
CORBA::Octet minor) const = 0;
/// Accessor for the output CDR stream
virtual TAO_OutputCDR &out_stream (void) = 0;
/// Consolidate newly received fragment with previously arrived
/// associated fragments to achieve consolidated message. All
/// fragments having been received previously are being managed
/// within implementation. If reliable transport is used (like TCP)
/// this operation will be invoked with fragments being received
/// partially ordered, last fragment being received last. Otherwise
/// If un-reliable transport is used (like UDP) fragments may be
/// received dis-ordered, and must be ordered before consolidation
/// within implementation. @return 0 on success and @a con_msg
/// points to consolidated message, 1 if there are still fragmens
/// outstanding, in case of error -1 is being returned. The
/// implementation is responsible to release @a qd.
virtual int consolidate_fragmented_message (TAO_Queued_Data *qd,
TAO_Queued_Data *&con_msg) = 0;
/// Discard all fragments associated to request-id encoded in
/// cancel_request. Transport implementaion guarantees that this
/// operation will never be invoked // concurrently by multiplpe
/// threads nor concurrently to consolidate_fragmented_message
/// @return -1 on failure, 0 on success, 1 no fragment on stack
/// relating to CancelRequest.
virtual int discard_fragmented_message (const TAO_Queued_Data *cancel_request) = 0;
/// Outgoing GIOP message fragmentation strategy.
virtual TAO_GIOP_Fragmentation_Strategy * fragmentation_strategy (void) = 0;
};
TAO_END_VERSIONED_NAMESPACE_DECL
#include /**/ "ace/post.h"
#endif /*TAO_PLUGGABLE_MESSAGING_H*/
|