summaryrefslogtreecommitdiff
path: root/TAO/tao/Asynch_Invocation.i
blob: 1d6825312211a5f2acfc888fa39b87e6cc791953 (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
// This	may look like C, but it's really -*- C++ -*-
//
// $Id$
//

#if (TAO_HAS_MINIMUM_CORBA == 0)

ACE_INLINE
TAO_GIOP_Asynch_Invocation::TAO_GIOP_Asynch_Invocation (
    TAO_Stub *stub,
    const char *operation,
    CORBA::ULong opname_len,
    CORBA::Boolean argument_flag,
    TAO_ORB_Core *orb_core
  )
  : TAO_GIOP_Invocation	(stub,
			 operation,
			 opname_len,
			 argument_flag,
			 orb_core),
    rd_	(0)
{
}

#endif /* TAO_HAS_MINIMUM_CORBA == 0 */

// ********************************************************************

#if (TAO_HAS_AMI_CALLBACK == 1) || (TAO_HAS_AMI_POLLER == 1)

ACE_INLINE
TAO_GIOP_Twoway_Asynch_Invocation::TAO_GIOP_Twoway_Asynch_Invocation (
    TAO_Stub *stub,
    const char *operation,
    CORBA::ULong opname_len,
    CORBA::Boolean argument_flag,
    TAO_ORB_Core *orb_core,
    const TAO_Reply_Handler_Skeleton &reply_handler_skel,
    Messaging::ReplyHandler_ptr	reply_handler_ptr
  )
  : TAO_GIOP_Asynch_Invocation (stub,
				operation,
				opname_len,
				argument_flag,
				orb_core)
{
  // New reply dispatcher on the heap, because
  // we	will go	out of scope and hand over the
  // reply dispatcher to the ORB.
  // So	this->rd_ is 0,	because	we do not need to
  // hold a pointer to it.
  ACE_NEW (this->rd_,
	   TAO_Asynch_Reply_Dispatcher (reply_handler_skel,
					reply_handler_ptr));
}

#endif /* (TAO_HAS_AMI_CALLBACK == 1) || (TAO_HAS_AMI_POLLER == 1) == 0 */