Revert "Use a variable on the stack to not have a temporary in the call"
[ACE_TAO.git] / ACE / ace / Reverse_Lock_T.h
blob9f0d2ae659f3bb954aff1c99ca01e0ad65e60f0f
1 // -*- C++ -*-
3 //==========================================================================
4 /**
5 * @file Reverse_Lock_T.h
7 * @author Douglas C. Schmidt <d.schmidt@vanderbilt.edu>
8 */
9 //==========================================================================
11 #ifndef ACE_REVERSE_LOCK_T_H
12 #define ACE_REVERSE_LOCK_T_H
13 #include /**/ "ace/pre.h"
15 #include "ace/Lock.h"
17 #if !defined (ACE_LACKS_PRAGMA_ONCE)
18 # pragma once
19 #endif /* ACE_LACKS_PRAGMA_ONCE */
21 ACE_BEGIN_VERSIONED_NAMESPACE_DECL
23 /**
24 * @namespace ACE_Acquire_Method
26 * @brief An enum namespace.
28 * These enums should have been inside the reverse lock class, but
29 * some lame compilers cannot handle enums inside template classes.
31 * The METHOD_TYPE is used to indicate which acquire() method will be
32 * called on the real lock when the release() method is called on the
33 * reverse lock. REGULAR indicated the acquire() method, READ
34 * indicates the acquire_read() method, and WRITE indicates the
35 * acquire_write() method. Note that the try_*() methods are not
36 * represented here because we have to make sure that the release()
37 * method on the reverse lock acquires a lock on the real lock.
38 **/
39 namespace ACE_Acquire_Method
41 enum METHOD_TYPE
43 ACE_REGULAR,
44 ACE_READ,
45 ACE_WRITE
49 /**
50 * @class ACE_Reverse_Lock
52 * @brief A reverse (or anti) lock.
54 * This is an interesting adapter class that changes a lock into
55 * a reverse lock, i.e., <acquire> on this class calls <release>
56 * on the lock, and <release> on this class calls <acquire> on
57 * the lock.
58 * One motivation for this class is when we temporarily want to
59 * release a lock (which we have already acquired) but then
60 * reacquire it soon after. An alternative design would be to
61 * add a Anti_Guard or Reverse_Guard class which would <release>
62 * on construction and <acquire> destruction. However, there
63 * are *many* varieties of the Guard class and this design
64 * choice would lead to at least 6 new classes. One new
65 * ACE_Reverse_Lock class seemed more reasonable.
67 template <class ACE_LOCKING_MECHANISM>
68 class ACE_Reverse_Lock : public ACE_Lock
70 public:
71 typedef ACE_LOCKING_MECHANISM ACE_LOCK;
73 // = Initialization/Finalization methods.
75 /// Constructor. All locking requests will be forwarded to @a lock.
76 ACE_Reverse_Lock (ACE_LOCKING_MECHANISM &lock,
77 ACE_Acquire_Method::METHOD_TYPE acquire_method = ACE_Acquire_Method::ACE_REGULAR);
79 /// Destructor. If <lock_> was not passed in by the user, it will be
80 /// deleted.
81 virtual ~ACE_Reverse_Lock () = default;
83 // = Lock accessors.
84 /// Release the lock.
85 virtual int acquire ();
87 /// Release the lock.
88 virtual int tryacquire ();
90 /// Acquire the lock.
91 virtual int release ();
93 /// Release the lock.
94 virtual int acquire_read ();
96 /// Release the lock.
97 virtual int acquire_write ();
99 /// Release the lock.
100 virtual int tryacquire_read ();
102 /// Release the lock.
103 virtual int tryacquire_write ();
105 /// Release the lock.
106 virtual int tryacquire_write_upgrade ();
108 /// Explicitly destroy the lock.
109 virtual int remove ();
111 private:
112 /// The concrete locking mechanism that all the methods delegate to.
113 ACE_LOCKING_MECHANISM &lock_;
115 /// This indicates what kind of acquire method will be called.
116 ACE_Acquire_Method::METHOD_TYPE acquire_method_;
119 ACE_END_VERSIONED_NAMESPACE_DECL
121 #if defined (__ACE_INLINE__)
122 #include "ace/Reverse_Lock_T.inl"
123 #endif /* __ACE_INLINE__ */
125 #include "ace/Reverse_Lock_T.cpp"
127 #include /**/ "ace/post.h"
128 #endif /* ACE_REVERSE_LOCK_T_H */