3 //=============================================================================
5 * @file Name_Request_Reply.h
7 * Define the format used to exchange messages between the
8 * ACE_Name Server and its clients.
10 * @author Gerhard Lenzer
11 * @author Douglas C. Schmidt
12 * @author Prashant Jain
14 //=============================================================================
17 #ifndef ACE_NAME_REQUEST_REPLY_H
18 #define ACE_NAME_REQUEST_REPLY_H
20 #include /**/ "ace/pre.h"
22 #include "ace/Basic_Types.h"
24 #if !defined (ACE_LACKS_PRAGMA_ONCE)
26 #endif /* ACE_LACKS_PRAGMA_ONCE */
28 ACE_BEGIN_VERSIONED_NAMESPACE_DECL
33 * @class ACE_Name_Request
35 * @brief Message format for delivering requests to the ACE_Name Server.
37 * This class is implemented to minimize data copying. In
38 * particular, all marshaling is done in situ...
40 class ACE_Export ACE_Name_Request
43 /// Request message types.
53 LIST_NAME_ENTRIES
= 06,
54 LIST_VALUE_ENTRIES
= 016,
55 LIST_TYPE_ENTRIES
= 026,
59 // Mask for bitwise operation used for table lookup
60 /// Mask for lookup of operation
62 /// Mask for lookup of list_operation
65 /// Class-specific constant values.
66 MAX_NAME_LENGTH
= MAXPATHLEN
+ 1
69 /// Default constructor.
72 /// Create a ACE_Name_Request message.
73 ACE_Name_Request (ACE_INT32 msg_type
, // Type of request.
74 const ACE_WCHAR_T name
[], //
75 const ACE_UINT32 name_length
,
76 const ACE_WCHAR_T value
[],
77 const ACE_UINT32 value_length
,
79 const ACE_UINT32 type_length
,
80 ACE_Time_Value
*timeout
= 0); // Max time willing to wait for request.
82 /// Initialize length_ in order to ensure correct byte ordering
83 /// before a request is sent.
86 // = Set/get the length of the encoded/decoded message.
87 ACE_UINT32
length () const;
88 void length (ACE_UINT32
);
90 // = Set/get the type of the message.
91 ACE_INT32
msg_type () const;
92 void msg_type (ACE_INT32
);
94 // = Set/get the blocking semantics.
95 ACE_UINT32
block_forever () const;
96 void block_forever (ACE_UINT32
);
98 // = Set/get the timeout.
99 ACE_Time_Value
timeout () const;
100 void timeout (const ACE_Time_Value timeout
);
102 // = Set/get the name
103 const ACE_WCHAR_T
*name () const;
104 void name (const ACE_WCHAR_T
*);
106 // = Set/get the value
107 const ACE_WCHAR_T
*value () const;
108 void value (const ACE_WCHAR_T
*);
110 // = Set/get the type
111 const char *type () const;
112 void type (const char *);
114 // = Set/get the len of name
115 ACE_UINT32
name_len () const;
116 void name_len (ACE_UINT32
);
118 // = Set/get the len of value
119 ACE_UINT32
value_len () const;
120 void value_len (ACE_UINT32
);
122 // = Set/get the len of type
123 ACE_UINT32
type_len () const;
124 void type_len (ACE_UINT32
);
126 /// Encode the message before transmission.
127 int encode (void *&);
129 /// Decode message after reception.
132 /// Print out the values of the message for debugging purposes.
136 // = The 5 fields in the <Transfer> struct are transmitted to the server.
137 // The remaining 2 fields are not tranferred -- they are used only on
138 // the server-side to simplify lookups.
142 /// Length of entire request.
145 /// Type of the request (i.e., <BIND>, <REBIND>, <RESOLVE>, and <UNBIND>).
146 ACE_UINT32 msg_type_
;
148 /// Indicates if we should block forever. If 0, then <secTimeout_>
149 /// and <usecTimeout_> indicates how long we should wait.
150 ACE_UINT32 block_forever_
;
152 /// Max seconds willing to wait for name if not blocking forever.
153 ACE_UINT64 sec_timeout_
;
155 /// Max micro seconds to wait for name if not blocking forever.
156 ACE_UINT32 usec_timeout_
;
158 /// Len of name in bytes
159 ACE_UINT32 name_len_
;
161 /// Len of value in bytes
162 ACE_UINT32 value_len_
;
164 /// Len of type in bytes
165 ACE_UINT32 type_len_
;
167 /// The data portion contains the <name_>
168 /// followed by the <value_>
169 /// followed by the <type_>.
170 ACE_WCHAR_T data_
[MAX_NAME_LENGTH
+ MAXPATHLEN
+ MAXPATHLEN
+ 2];
176 /// Pointer to the beginning of the name in this->data_.
179 /// Pointer to the beginning of the value in this->data_;
182 /// Pointer to the beginning of the type in this->data_;
187 * @class ACE_Name_Reply
189 * @brief Message format for delivering replies from the ACE_Name Server.
191 * This class is implemented to minimize data copying. In
192 * particular, all marshaling is done in situ...
194 class ACE_Export ACE_Name_Reply
199 /// Class-specific constant values.
200 MAX_NAME_LENGTH
= MAXPATHLEN
+ 1
203 /// Default constructor.
206 /// Create a ACE_Name_Reply message.
207 ACE_Name_Reply (ACE_UINT32 type
, ACE_UINT32 err
); // Type of reply.
209 /// Initialize length_ in order to ensure correct byte ordering
210 /// before a reply is sent.
213 // = Set/get the length of the encoded/decoded message.
214 ACE_UINT32
length () const;
215 void length (ACE_UINT32
);
217 // = Set/get the type of the message.
218 ACE_INT32
msg_type () const;
219 void msg_type (ACE_INT32
);
221 // = Set/get the status of the reply (0 == success, -1 == failure).
222 ACE_INT32
status () const;
223 void status (ACE_INT32
);
225 // = Set/get the errno of a failed reply.
226 ACE_UINT32
errnum () const;
227 void errnum (ACE_UINT32
);
229 /// Encode the message before transfer.
230 int encode (void *&);
232 /// Decode a message after reception.
235 /// Print out the values of the message for debugging purposes.
239 // = The 3 fields in the <Transfer> struct are transmitted to the server.
243 /// Length of entire reply.
246 /// Type of the reply, i.e., success (0) or failure (-1).
249 /// Indicates why error occurred if <this->type_> == failure (-1).
250 /// Typical reasons include: @c ETIME (if the client timed out after
251 /// waiting for the name).
259 ACE_END_VERSIONED_NAMESPACE_DECL
261 #include /**/ "ace/post.h"
263 #endif /* ACE_NAME_REQUEST_REPLY_H */