xref: /AOO41X/main/sd/source/ui/inc/UpdateLockManager.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 SD_UPDATE_LOCK_MANAGER_HXX
29*cdf0e10cSrcweir #define SD_UPDATE_LOCK_MANAGER_HXX
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #include <memory>
32*cdf0e10cSrcweir 
33*cdf0e10cSrcweir namespace sd {
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir class ViewShellBase;
36*cdf0e10cSrcweir 
37*cdf0e10cSrcweir /** Manage update locks of ViewShellBase objects.
38*cdf0e10cSrcweir     A ViewShellBase object is locked while views are switched in order to
39*cdf0e10cSrcweir     avoid unnecessary repaints of views and object bars.
40*cdf0e10cSrcweir     Locking a ViewShellBase locks the frame::XLayoutManager and prevents
41*cdf0e10cSrcweir     Activate() and Deactivate() calls at ViewShell objects being processed.
42*cdf0e10cSrcweir 
43*cdf0e10cSrcweir     The main responsibility of this class is find the right moment to unlock
44*cdf0e10cSrcweir     the managed ViewShellBase object: Only Lock() has to be called from the
45*cdf0e10cSrcweir     outside (usually from PaneManager).  Unlock() is called by this class
46*cdf0e10cSrcweir     itself.  When all else fails it has a timer that calls Unlock()
47*cdf0e10cSrcweir     eventually.
48*cdf0e10cSrcweir */
49*cdf0e10cSrcweir class UpdateLockManager
50*cdf0e10cSrcweir {
51*cdf0e10cSrcweir public:
52*cdf0e10cSrcweir     /** The newly created instance supports locking for the specified
53*cdf0e10cSrcweir         ViewShellBase object by default.  Call Disable() for Lock() and
54*cdf0e10cSrcweir         Unlock() calls being ignored.
55*cdf0e10cSrcweir     */
56*cdf0e10cSrcweir     UpdateLockManager (ViewShellBase& rBase);
57*cdf0e10cSrcweir     ~UpdateLockManager (void);
58*cdf0e10cSrcweir 
59*cdf0e10cSrcweir     /** For e.g. the PresentationViewShellBase locking is not necessary and
60*cdf0e10cSrcweir         does lead to problems.  This method lets Lock() and Unlock() calls
61*cdf0e10cSrcweir         be ignored and thus turns locking essentially off.
62*cdf0e10cSrcweir     */
63*cdf0e10cSrcweir     void Disable (void);
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir     /** Lock some UI updates.  For every call to this method a call to
66*cdf0e10cSrcweir         Unlock() is required to really unlock.
67*cdf0e10cSrcweir     */
68*cdf0e10cSrcweir     void Lock (void);
69*cdf0e10cSrcweir 
70*cdf0e10cSrcweir     /** When called as many times as Lock() has been called before then the
71*cdf0e10cSrcweir         ViewShellBase object is unlocked.
72*cdf0e10cSrcweir     */
73*cdf0e10cSrcweir     void Unlock (void);
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir     /** Return whether the ViewShellBase object is locked.  When locking is
76*cdf0e10cSrcweir         disabled, i.e. Disable() has been called before, then this method
77*cdf0e10cSrcweir         always returns <FALSE/>.
78*cdf0e10cSrcweir     */
79*cdf0e10cSrcweir     bool IsLocked (void) const;
80*cdf0e10cSrcweir 
81*cdf0e10cSrcweir private:
82*cdf0e10cSrcweir     class Implementation;
83*cdf0e10cSrcweir     Implementation* mpImpl;
84*cdf0e10cSrcweir 
85*cdf0e10cSrcweir     UpdateLockManager (const UpdateLockManager&); // Not supported.
86*cdf0e10cSrcweir     UpdateLockManager& operator= (const UpdateLockManager&); // Not supported.
87*cdf0e10cSrcweir };
88*cdf0e10cSrcweir 
89*cdf0e10cSrcweir } // end of namespace sd
90*cdf0e10cSrcweir 
91*cdf0e10cSrcweir #endif
92*cdf0e10cSrcweir 
93