blob: e309804aab4ddb539e0b3a80fade759faeec62cd (
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
131
132
133
134
135
136
137
138
139
140
141
|
// This may look like C, but it's really -*- C++ -*-
//=============================================================================
/**
* @file operation_details.h
*
* $Id$
*
* @author Bala Natarajan <bala@cs.wustl.edu>
*/
//=============================================================================
#ifndef TAO_OPERATION_DETAILS_H
#define TAO_OPERATION_DETAILS_H
#include "ace/pre.h"
#include "corbafwd.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#include "Service_Context.h"
#include "target_specification.h"
// @@ Bala: Why is this not part of the RequestHeader?!
/**
* @class TAO_Operation_Details
*
* @brief Class with operation details
*
* This class stores some of the "operation" details that would be
* required by the invocation classes. This class is in its
* infancy now but I expect this one to grow as we come with
* different varieties of use cases.
*/
class TAO_Export TAO_Operation_Details
{
public:
///Constructor
TAO_Operation_Details (const char *name,
CORBA::ULong len,
CORBA::Boolean argument_flag);
/// Operation name
const char* opname (void) const;
/// Length of the operation name
CORBA::ULong opname_len (void) const;
/// Return the flag that indicates whether the operation has any
/// arguments
CORBA::Boolean argument_flag (void) const;
/// Set the response flags
void response_flags (CORBA::Octet flags);
/// Get the response flags
CORBA::Octet response_flags (void);
CORBA::Octet response_flags (void) const;
/// Get the service context list
IOP::ServiceContextList &request_service_info (void);
const IOP::ServiceContextList &request_service_info (void) const;
IOP::ServiceContextList &reply_service_info (void);
const IOP::ServiceContextList &reply_service_info (void) const;
/// Access the TAO_Service_Context
TAO_Service_Context &request_service_context (void);
const TAO_Service_Context &request_service_context (void) const;
TAO_Service_Context &reply_service_context (void);
const TAO_Service_Context &reply_service_context (void) const;
void request_id (CORBA::ULong id);
/// Modify request id's for a BiDirectional setup
void modify_request_id (int originator);
/// Return the request ID associated with the operation
CORBA::ULong request_id (void);
CORBA::ULong request_id (void) const;
/// Accessor method for the addressing mode
TAO_Target_Specification::TAO_Target_Address addressing_mode (void);
TAO_Target_Specification::TAO_Target_Address
addressing_mode (void) const;
/// Set method for the addressing mode
void addressing_mode (CORBA::Short addr);
private:
/// Name of the operation being invoked.
const char *opname_;
/// Precalculated length of opname_.
CORBA::ULong opname_len_;
/// Request ID of this operation.
CORBA::ULong request_id_;
/**
* Flag that indicates whether the operation has any arguments. If
* there are any arguments the flag will have a value of 1, 0
* otherwise.
*/
CORBA::Boolean argument_flag_;
/// Response flags
CORBA::Octet response_flags_;
/// The ServiceContextList sent to the server side. Only valid
/// when sending a request.
TAO_Service_Context request_service_info_;
/// The ServiceContextList received from the server side. Only
/// valid when sending a request.
TAO_Service_Context reply_service_info_;
// The first element of header is service context list;
// transactional context would be acquired here using the
// transaction service APIs. Other kinds of context are as yet
// undefined.
//
/// Addressing mode for this request.
TAO_Target_Specification::TAO_Target_Address addressing_mode_;
};
#if defined (__ACE_INLINE__)
# include "operation_details.i"
#endif /* __ACE_INLINE__ */
#include "ace/post.h"
#endif /* TAO_OPERATION_DETAILS_H */
|