summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/orbsvcs/Event/EC_Command.h
blob: c32e4ad3b346aaade4eea163a388c0aeca0a27f4 (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
/* -*- C++ -*- */
// $Id$
//
// ============================================================================
//
// = LIBRARY
//   ORBSVCS Real-time Event Channel
//
// = FILENAME
//   EC_Command
//
// = AUTHOR
//   Carlos O'Ryan (coryan@cs.wustl.edu)
//
// = CREDITS
//   Based on previous work by Tim Harrison (harrison@cs.wustl.edu)
//   and other members of the DOC group.
//   More details can be found in:
//   http://www.cs.wustl.edu/~schmidt/oopsla.ps.gz
//   http://www.cs.wustl.edu/~schmidt/JSAC-98.ps.gz
//
//
// ============================================================================

#ifndef TAO_EC_COMMAND_H
#define TAO_EC_COMMAND_H

#include "ace/Functor.h"

#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */

template<class Target, class Object>
class TAO_EC_Connected_Command : public ACE_Command_Base
{
  // = TITLE
  //   EC_Connected_Command
  //
  // = DESCRIPTION
  //   Implements a Command object that invokes the connected_i() method
  //   on the target, passing an argument of type Object.
  //
  // = MEMORY MANAGMENT
  //   It does not assume ownership of Object nor the Target
  //   arguments.
  //   Usually allocated from the heap or an allocator; but it is not
  //   self-managed.
  //
  // = LOCKING
  //   No provisions for locking, access must be serialized
  //   externally.
  //
  // = TODO
  //
public:
  TAO_EC_Connected_Command (Target *target,
                            Object *object);
  // constructor...

  virtual int execute (void *arg);
  // The callback method, if the argument is not nil it is interpreted
  // as a CORBA::Environment.

private:
  Target *target_;
  // The target

  Object *object_;
  // The argument
};

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

template<class Target, class Object>
class TAO_EC_Disconnected_Command : public ACE_Command_Base
{
  // = TITLE
  //   EC_Disconnected_Command
  //
  // = DESCRIPTION
  //   Implements a Command object that invokes the disconnected_i()
  //   method on the target, passing an argument of type Object.
  //
  // = MEMORY MANAGMENT
  //   It does not assume ownership of Object nor the Target
  //   arguments.
  //   Usually allocated from the heap or an allocator; but it is not
  //   self-managed.
  //
  // = LOCKING
  //   No provisions for locking, access must be serialized
  //   externally.
  //
  // = TODO
  //
public:
  TAO_EC_Disconnected_Command (Target *target,
                               Object *object);
  // constructor...

  virtual int execute (void *arg);
  // The callback method, if the argument is not nil it is interpreted
  // as a CORBA::Environment.

private:
  Target *target_;
  // The target

  Object *object_;
  // The argument
};

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

#if defined (__ACE_INLINE__)
#include "EC_Command.i"
#endif /* __ACE_INLINE__ */

#if defined (ACE_TEMPLATES_REQUIRE_SOURCE)
#include "EC_Command.cpp"
#endif /* ACE_TEMPLATES_REQUIRE_SOURCE */

#if defined (ACE_TEMPLATES_REQUIRE_PRAGMA)
#pragma implementation ("EC_Command.cpp")
#endif /* ACE_TEMPLATES_REQUIRE_PRAGMA */

#endif /* TAO_EC_COMMAND_H */