xref: /trunk/main/framework/inc/threadhelp/readguard.hxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir #ifndef __FRAMEWORK_THREADHELP_READGUARD_HXX_
29*cdf0e10cSrcweir #define __FRAMEWORK_THREADHELP_READGUARD_HXX_
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
32*cdf0e10cSrcweir //  my own includes
33*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir #include <threadhelp/inoncopyable.h>
36*cdf0e10cSrcweir #include <threadhelp/irwlock.h>
37*cdf0e10cSrcweir 
38*cdf0e10cSrcweir //#ifndef __FRAMEWORK_THREADHELP_THREADHELPBASE_HXX_
39*cdf0e10cSrcweir //#include <threadhelp/threadhelpbase.hxx>
40*cdf0e10cSrcweir //#endif
41*cdf0e10cSrcweir 
42*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
43*cdf0e10cSrcweir //  interface includes
44*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
45*cdf0e10cSrcweir 
46*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
47*cdf0e10cSrcweir //  other includes
48*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
49*cdf0e10cSrcweir #include <sal/types.h>
50*cdf0e10cSrcweir 
51*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
52*cdf0e10cSrcweir //  namespace
53*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
54*cdf0e10cSrcweir 
55*cdf0e10cSrcweir namespace framework{
56*cdf0e10cSrcweir 
57*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
58*cdf0e10cSrcweir //  const
59*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
60*cdf0e10cSrcweir 
61*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
62*cdf0e10cSrcweir //  declarations
63*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir /*-************************************************************************************************************//**
66*cdf0e10cSrcweir     @short          implement a guard to set read locks
67*cdf0e10cSrcweir     @descr          This guard should be used to set a lock for reading object internal member.
68*cdf0e10cSrcweir                     Nobody can control it but don't use member after successfuly locking for writing!
69*cdf0e10cSrcweir                     We never need a own mutex to safe our internal member access - because
70*cdf0e10cSrcweir                     a guard is used as function-local member only. There exist no multithreaded access to it realy ...
71*cdf0e10cSrcweir 
72*cdf0e10cSrcweir     @attention      a) To prevent us against wrong using, the default ctor, copy ctor and the =operator are maked private!
73*cdf0e10cSrcweir                     b) Use interface "IRWLock" of set LockHelper only - because we must support a finer granularity of locking.
74*cdf0e10cSrcweir                        Interface "IMutex" should be used by easier guard implementations ... like "ResetableGuard"!
75*cdf0e10cSrcweir 
76*cdf0e10cSrcweir     @implements     -
77*cdf0e10cSrcweir     @base           INonCopyable
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir     @devstatus      ready to use
80*cdf0e10cSrcweir *//*-*************************************************************************************************************/
81*cdf0e10cSrcweir class ReadGuard : private INonCopyable
82*cdf0e10cSrcweir {
83*cdf0e10cSrcweir     //-------------------------------------------------------------------------------------------------------------
84*cdf0e10cSrcweir     //  public methods
85*cdf0e10cSrcweir     //-------------------------------------------------------------------------------------------------------------
86*cdf0e10cSrcweir     public:
87*cdf0e10cSrcweir 
88*cdf0e10cSrcweir         /*-****************************************************************************************************//**
89*cdf0e10cSrcweir             @short      ctor
90*cdf0e10cSrcweir             @descr      These ctors initialize the guard with a reference to used lock member of object to protect.
91*cdf0e10cSrcweir                         Null isn't allowed as value!
92*cdf0e10cSrcweir 
93*cdf0e10cSrcweir             @seealso    -
94*cdf0e10cSrcweir 
95*cdf0e10cSrcweir             @param      "pLock" ,reference to used lock member of object to protect
96*cdf0e10cSrcweir             @param      "rLock" ,reference to used lock member of object to protect
97*cdf0e10cSrcweir             @return     -
98*cdf0e10cSrcweir 
99*cdf0e10cSrcweir             @onerror    -
100*cdf0e10cSrcweir         *//*-*****************************************************************************************************/
101*cdf0e10cSrcweir         inline ReadGuard( IRWLock* pLock )
102*cdf0e10cSrcweir             :   m_pLock     ( pLock     )
103*cdf0e10cSrcweir             ,   m_bLocked   ( sal_False )
104*cdf0e10cSrcweir         {
105*cdf0e10cSrcweir             lock();
106*cdf0e10cSrcweir         }
107*cdf0e10cSrcweir 
108*cdf0e10cSrcweir         //*********************************************************************************************************
109*cdf0e10cSrcweir         inline ReadGuard( IRWLock& rLock )
110*cdf0e10cSrcweir             :   m_pLock     ( &rLock    )
111*cdf0e10cSrcweir             ,   m_bLocked   ( sal_False )
112*cdf0e10cSrcweir         {
113*cdf0e10cSrcweir             lock();
114*cdf0e10cSrcweir         }
115*cdf0e10cSrcweir 
116*cdf0e10cSrcweir         /*-****************************************************************************************************//**
117*cdf0e10cSrcweir             @short      dtor
118*cdf0e10cSrcweir             @descr      We unlock the used lock member automaticly if user forget it.
119*cdf0e10cSrcweir 
120*cdf0e10cSrcweir             @seealso    -
121*cdf0e10cSrcweir 
122*cdf0e10cSrcweir             @param      -
123*cdf0e10cSrcweir             @return     -
124*cdf0e10cSrcweir 
125*cdf0e10cSrcweir             @onerror    -
126*cdf0e10cSrcweir         *//*-*****************************************************************************************************/
127*cdf0e10cSrcweir         inline ~ReadGuard()
128*cdf0e10cSrcweir         {
129*cdf0e10cSrcweir             unlock();
130*cdf0e10cSrcweir         }
131*cdf0e10cSrcweir 
132*cdf0e10cSrcweir         /*-****************************************************************************************************//**
133*cdf0e10cSrcweir             @short      set read lock
134*cdf0e10cSrcweir             @descr      Call this method to set the read lock. The call will block till all current threads are synchronized!
135*cdf0e10cSrcweir 
136*cdf0e10cSrcweir             @seealso    method unlock()
137*cdf0e10cSrcweir 
138*cdf0e10cSrcweir             @param      -
139*cdf0e10cSrcweir             @return     -
140*cdf0e10cSrcweir 
141*cdf0e10cSrcweir             @onerror    -
142*cdf0e10cSrcweir         *//*-*****************************************************************************************************/
143*cdf0e10cSrcweir         inline void lock()
144*cdf0e10cSrcweir         {
145*cdf0e10cSrcweir             if( m_bLocked == sal_False )
146*cdf0e10cSrcweir             {
147*cdf0e10cSrcweir                 m_pLock->acquireReadAccess();
148*cdf0e10cSrcweir                 m_bLocked = sal_True;
149*cdf0e10cSrcweir             }
150*cdf0e10cSrcweir         }
151*cdf0e10cSrcweir 
152*cdf0e10cSrcweir         /*-****************************************************************************************************//**
153*cdf0e10cSrcweir             @short      unset read lock
154*cdf0e10cSrcweir             @descr      Call this method to unlock the rw-lock temp.!
155*cdf0e10cSrcweir                         Normaly we do it at dtor automaticly for you ...
156*cdf0e10cSrcweir 
157*cdf0e10cSrcweir             @seealso    method lock()
158*cdf0e10cSrcweir 
159*cdf0e10cSrcweir             @param      -
160*cdf0e10cSrcweir             @return     -
161*cdf0e10cSrcweir 
162*cdf0e10cSrcweir             @onerror    -
163*cdf0e10cSrcweir         *//*-*****************************************************************************************************/
164*cdf0e10cSrcweir         inline void unlock()
165*cdf0e10cSrcweir         {
166*cdf0e10cSrcweir             if( m_bLocked == sal_True )
167*cdf0e10cSrcweir             {
168*cdf0e10cSrcweir                 m_pLock->releaseReadAccess();
169*cdf0e10cSrcweir                 m_bLocked = sal_False;
170*cdf0e10cSrcweir             }
171*cdf0e10cSrcweir         }
172*cdf0e10cSrcweir 
173*cdf0e10cSrcweir     //-------------------------------------------------------------------------------------------------------------
174*cdf0e10cSrcweir     //  private methods
175*cdf0e10cSrcweir     //-------------------------------------------------------------------------------------------------------------
176*cdf0e10cSrcweir     private:
177*cdf0e10cSrcweir 
178*cdf0e10cSrcweir         /*-****************************************************************************************************//**
179*cdf0e10cSrcweir             @short      disable using of these functions!
180*cdf0e10cSrcweir             @descr      It's not allowed to use this methods. Different problem can occure otherwise.
181*cdf0e10cSrcweir                         Thats why we disable it by make it private.
182*cdf0e10cSrcweir 
183*cdf0e10cSrcweir             @seealso    other ctor
184*cdf0e10cSrcweir 
185*cdf0e10cSrcweir             @param      -
186*cdf0e10cSrcweir             @return     -
187*cdf0e10cSrcweir 
188*cdf0e10cSrcweir             @onerror    -
189*cdf0e10cSrcweir         *//*-*****************************************************************************************************/
190*cdf0e10cSrcweir         ReadGuard();
191*cdf0e10cSrcweir 
192*cdf0e10cSrcweir     //-------------------------------------------------------------------------------------------------------------
193*cdf0e10cSrcweir     //  private member
194*cdf0e10cSrcweir     //-------------------------------------------------------------------------------------------------------------
195*cdf0e10cSrcweir     private:
196*cdf0e10cSrcweir 
197*cdf0e10cSrcweir         IRWLock*    m_pLock     ;   /// reference to lock-member of protected object
198*cdf0e10cSrcweir         sal_Bool    m_bLocked   ;   /// protection against multiple lock calls without unlock!
199*cdf0e10cSrcweir 
200*cdf0e10cSrcweir };      //  class ReadGuard
201*cdf0e10cSrcweir 
202*cdf0e10cSrcweir }       //  namespace framework
203*cdf0e10cSrcweir 
204*cdf0e10cSrcweir #endif  //  #ifndef __FRAMEWORK_THREADHELP_READGUARD_HXX_
205