1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_sd.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #include "UpdateLockManager.hxx"
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski #include "MutexOwner.hxx"
30*b1cdbd2cSJim Jagielski #include "ViewShellBase.hxx"
31*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XLayoutManager.hpp>
32*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XLayoutManagerEventBroadcaster.hpp>
33*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/LayoutManagerEvents.hpp>
34*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/XPropertySet.hpp>
35*b1cdbd2cSJim Jagielski #include <cppuhelper/compbase1.hxx>
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski #include <vcl/timer.hxx>
38*b1cdbd2cSJim Jagielski #include <sfx2/viewfrm.hxx>
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
41*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
42*b1cdbd2cSJim Jagielski 
43*b1cdbd2cSJim Jagielski namespace {
44*b1cdbd2cSJim Jagielski typedef cppu::WeakComponentImplHelper1<frame::XLayoutManagerListener> InterfaceBase;
45*b1cdbd2cSJim Jagielski }
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski namespace sd {
48*b1cdbd2cSJim Jagielski 
49*b1cdbd2cSJim Jagielski 
50*b1cdbd2cSJim Jagielski /** This implementation class not only implements the Lock() and Unlock()
51*b1cdbd2cSJim Jagielski     methods but as well listens for the right combination of events to call
52*b1cdbd2cSJim Jagielski     Unlock() when all is ready after the PaneManager has switched (some of)
53*b1cdbd2cSJim Jagielski     its view shells.
54*b1cdbd2cSJim Jagielski */
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski class UpdateLockManager::Implementation
57*b1cdbd2cSJim Jagielski     : protected MutexOwner,
58*b1cdbd2cSJim Jagielski       public InterfaceBase
59*b1cdbd2cSJim Jagielski {
60*b1cdbd2cSJim Jagielski public:
61*b1cdbd2cSJim Jagielski     Implementation (ViewShellBase& rBase);
62*b1cdbd2cSJim Jagielski     virtual ~Implementation (void);
63*b1cdbd2cSJim Jagielski 
64*b1cdbd2cSJim Jagielski     void Lock (void);
65*b1cdbd2cSJim Jagielski     void Unlock (void);
66*b1cdbd2cSJim Jagielski     bool IsLocked (void) const;
67*b1cdbd2cSJim Jagielski 
68*b1cdbd2cSJim Jagielski     /** Unlock regardless of the current lock level.
69*b1cdbd2cSJim Jagielski     */
70*b1cdbd2cSJim Jagielski     void ForceUnlock (void);
71*b1cdbd2cSJim Jagielski 
72*b1cdbd2cSJim Jagielski private:
73*b1cdbd2cSJim Jagielski     ViewShellBase& mrBase;
74*b1cdbd2cSJim Jagielski     /// A lock level greater than 0 indicates that the ViewShellBase is locked.
75*b1cdbd2cSJim Jagielski     sal_Int32 mnLockDepth;
76*b1cdbd2cSJim Jagielski     /// The emergency timer to unlock the ViewShellBase when all else fails.
77*b1cdbd2cSJim Jagielski     Timer maTimer;
78*b1cdbd2cSJim Jagielski     /// Remember when to unlock after a layout event from frame::XLayoutManager
79*b1cdbd2cSJim Jagielski     bool mbUnlockOnNextLayout;
80*b1cdbd2cSJim Jagielski     /// Remember whether we are listening to the frame::XLayoutManager
81*b1cdbd2cSJim Jagielski     bool mbListenerIsRegistered;
82*b1cdbd2cSJim Jagielski     /// Remember whether the frame::XLayoutManager is locked.
83*b1cdbd2cSJim Jagielski     bool mbLayouterIsLocked;
84*b1cdbd2cSJim Jagielski     /** We hold a weak reference to the layout manager in order to have
85*b1cdbd2cSJim Jagielski         access to it even when the ViewShellBase object is not valid anymore
86*b1cdbd2cSJim Jagielski         and can not be used to obtain the layout manager.
87*b1cdbd2cSJim Jagielski     */
88*b1cdbd2cSJim Jagielski     WeakReference<frame::XLayoutManager> mxLayoutManager;
89*b1cdbd2cSJim Jagielski 
90*b1cdbd2cSJim Jagielski     //=====  frame::XLayoutEventListener  =====================================
91*b1cdbd2cSJim Jagielski 
92*b1cdbd2cSJim Jagielski     /** The event of the layouter are observed to find the best moment for
93*b1cdbd2cSJim Jagielski         unlocking.  This is the first layout after the lock level of the
94*b1cdbd2cSJim Jagielski         layouter drops to one (we hold a lock to it ourselves which we
95*b1cdbd2cSJim Jagielski         release when unlocking).
96*b1cdbd2cSJim Jagielski     */
97*b1cdbd2cSJim Jagielski     virtual void SAL_CALL layoutEvent (
98*b1cdbd2cSJim Jagielski         const lang::EventObject& xSource,
99*b1cdbd2cSJim Jagielski         sal_Int16 eLayoutEvent,
100*b1cdbd2cSJim Jagielski         const Any& rInfo)
101*b1cdbd2cSJim Jagielski         throw (uno::RuntimeException);
102*b1cdbd2cSJim Jagielski 
103*b1cdbd2cSJim Jagielski     //=====  lang::XEventListener  ============================================
104*b1cdbd2cSJim Jagielski     virtual void SAL_CALL
105*b1cdbd2cSJim Jagielski         disposing (const lang::EventObject& rEventObject)
106*b1cdbd2cSJim Jagielski         throw (::com::sun::star::uno::RuntimeException);
107*b1cdbd2cSJim Jagielski 
108*b1cdbd2cSJim Jagielski     virtual void SAL_CALL disposing (void);
109*b1cdbd2cSJim Jagielski 
110*b1cdbd2cSJim Jagielski     /** This is only a fallback to make the office usable when for some
111*b1cdbd2cSJim Jagielski         reason the intended way of unlocking it failed.
112*b1cdbd2cSJim Jagielski     */
113*b1cdbd2cSJim Jagielski     DECL_LINK(Timeout, void*);
114*b1cdbd2cSJim Jagielski 
115*b1cdbd2cSJim Jagielski     /** Convenience method that finds the layout manager associated with the
116*b1cdbd2cSJim Jagielski         frame that shows the ViewShellBase.
117*b1cdbd2cSJim Jagielski     */
118*b1cdbd2cSJim Jagielski     Reference<frame::XLayoutManager> GetLayoutManager (void);
119*b1cdbd2cSJim Jagielski 
120*b1cdbd2cSJim Jagielski     Implementation (const Implementation&); // Not implemented.
121*b1cdbd2cSJim Jagielski     Implementation& operator= (const Implementation&); // Not implemented.
122*b1cdbd2cSJim Jagielski };
123*b1cdbd2cSJim Jagielski 
124*b1cdbd2cSJim Jagielski 
125*b1cdbd2cSJim Jagielski 
126*b1cdbd2cSJim Jagielski 
127*b1cdbd2cSJim Jagielski //===== UpdateLockManager =====================================================
128*b1cdbd2cSJim Jagielski 
UpdateLockManager(ViewShellBase & rBase)129*b1cdbd2cSJim Jagielski UpdateLockManager::UpdateLockManager (ViewShellBase& rBase)
130*b1cdbd2cSJim Jagielski     : mpImpl(new Implementation(rBase))
131*b1cdbd2cSJim Jagielski {
132*b1cdbd2cSJim Jagielski     mpImpl->acquire();
133*b1cdbd2cSJim Jagielski }
134*b1cdbd2cSJim Jagielski 
135*b1cdbd2cSJim Jagielski 
136*b1cdbd2cSJim Jagielski 
~UpdateLockManager(void)137*b1cdbd2cSJim Jagielski UpdateLockManager::~UpdateLockManager (void)
138*b1cdbd2cSJim Jagielski {
139*b1cdbd2cSJim Jagielski     if (mpImpl != NULL)
140*b1cdbd2cSJim Jagielski     {
141*b1cdbd2cSJim Jagielski         mpImpl->ForceUnlock();
142*b1cdbd2cSJim Jagielski         mpImpl->release();
143*b1cdbd2cSJim Jagielski     }
144*b1cdbd2cSJim Jagielski }
145*b1cdbd2cSJim Jagielski 
146*b1cdbd2cSJim Jagielski 
147*b1cdbd2cSJim Jagielski 
148*b1cdbd2cSJim Jagielski 
Disable(void)149*b1cdbd2cSJim Jagielski void UpdateLockManager::Disable (void)
150*b1cdbd2cSJim Jagielski {
151*b1cdbd2cSJim Jagielski     if (mpImpl != NULL)
152*b1cdbd2cSJim Jagielski     {
153*b1cdbd2cSJim Jagielski         mpImpl->ForceUnlock();
154*b1cdbd2cSJim Jagielski         mpImpl->release();
155*b1cdbd2cSJim Jagielski         mpImpl = NULL;
156*b1cdbd2cSJim Jagielski     }
157*b1cdbd2cSJim Jagielski }
158*b1cdbd2cSJim Jagielski 
159*b1cdbd2cSJim Jagielski 
160*b1cdbd2cSJim Jagielski 
161*b1cdbd2cSJim Jagielski 
Lock(void)162*b1cdbd2cSJim Jagielski void UpdateLockManager::Lock (void)
163*b1cdbd2cSJim Jagielski {
164*b1cdbd2cSJim Jagielski     if (mpImpl != NULL)
165*b1cdbd2cSJim Jagielski         mpImpl->Lock();
166*b1cdbd2cSJim Jagielski }
167*b1cdbd2cSJim Jagielski 
168*b1cdbd2cSJim Jagielski 
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski 
Unlock(void)171*b1cdbd2cSJim Jagielski void UpdateLockManager::Unlock (void)
172*b1cdbd2cSJim Jagielski {
173*b1cdbd2cSJim Jagielski     if (mpImpl != NULL)
174*b1cdbd2cSJim Jagielski         mpImpl->Unlock();
175*b1cdbd2cSJim Jagielski }
176*b1cdbd2cSJim Jagielski 
177*b1cdbd2cSJim Jagielski 
178*b1cdbd2cSJim Jagielski 
179*b1cdbd2cSJim Jagielski 
IsLocked(void) const180*b1cdbd2cSJim Jagielski bool UpdateLockManager::IsLocked (void) const
181*b1cdbd2cSJim Jagielski {
182*b1cdbd2cSJim Jagielski     if (mpImpl != NULL)
183*b1cdbd2cSJim Jagielski         return mpImpl->IsLocked();
184*b1cdbd2cSJim Jagielski     else
185*b1cdbd2cSJim Jagielski         return false;
186*b1cdbd2cSJim Jagielski }
187*b1cdbd2cSJim Jagielski 
188*b1cdbd2cSJim Jagielski 
189*b1cdbd2cSJim Jagielski 
190*b1cdbd2cSJim Jagielski //===== UpdateLock::Implementation ============================================
191*b1cdbd2cSJim Jagielski 
Implementation(ViewShellBase & rBase)192*b1cdbd2cSJim Jagielski UpdateLockManager::Implementation::Implementation (ViewShellBase& rBase)
193*b1cdbd2cSJim Jagielski     : InterfaceBase(maMutex),
194*b1cdbd2cSJim Jagielski       mrBase(rBase),
195*b1cdbd2cSJim Jagielski       mnLockDepth(0),
196*b1cdbd2cSJim Jagielski       maTimer(),
197*b1cdbd2cSJim Jagielski       mbUnlockOnNextLayout(false),
198*b1cdbd2cSJim Jagielski       mbListenerIsRegistered(false),
199*b1cdbd2cSJim Jagielski       mbLayouterIsLocked(false)
200*b1cdbd2cSJim Jagielski {
201*b1cdbd2cSJim Jagielski }
202*b1cdbd2cSJim Jagielski 
203*b1cdbd2cSJim Jagielski 
204*b1cdbd2cSJim Jagielski 
205*b1cdbd2cSJim Jagielski 
~Implementation(void)206*b1cdbd2cSJim Jagielski UpdateLockManager::Implementation::~Implementation (void)
207*b1cdbd2cSJim Jagielski {
208*b1cdbd2cSJim Jagielski     OSL_ASSERT(mnLockDepth==0);
209*b1cdbd2cSJim Jagielski     ForceUnlock();
210*b1cdbd2cSJim Jagielski }
211*b1cdbd2cSJim Jagielski 
212*b1cdbd2cSJim Jagielski 
213*b1cdbd2cSJim Jagielski 
214*b1cdbd2cSJim Jagielski 
Lock(void)215*b1cdbd2cSJim Jagielski void UpdateLockManager::Implementation::Lock (void)
216*b1cdbd2cSJim Jagielski {
217*b1cdbd2cSJim Jagielski     ++mnLockDepth;
218*b1cdbd2cSJim Jagielski     if (mnLockDepth == 1)
219*b1cdbd2cSJim Jagielski     {
220*b1cdbd2cSJim Jagielski         Reference<frame::XLayoutManager> xLayouter (GetLayoutManager());
221*b1cdbd2cSJim Jagielski         if (xLayouter.is())
222*b1cdbd2cSJim Jagielski         {
223*b1cdbd2cSJim Jagielski             // Register as event listener.
224*b1cdbd2cSJim Jagielski             Reference<frame::XLayoutManagerEventBroadcaster> xBroadcaster (
225*b1cdbd2cSJim Jagielski                 xLayouter, UNO_QUERY);
226*b1cdbd2cSJim Jagielski             if (xBroadcaster.is())
227*b1cdbd2cSJim Jagielski             {
228*b1cdbd2cSJim Jagielski                 mbListenerIsRegistered = true;
229*b1cdbd2cSJim Jagielski                 xBroadcaster->addLayoutManagerEventListener(
230*b1cdbd2cSJim Jagielski                     Reference<frame::XLayoutManagerListener> (
231*b1cdbd2cSJim Jagielski                         static_cast<XWeak*>(this), UNO_QUERY) );
232*b1cdbd2cSJim Jagielski             }
233*b1cdbd2cSJim Jagielski 
234*b1cdbd2cSJim Jagielski             // Lock the layout manager.
235*b1cdbd2cSJim Jagielski             mbLayouterIsLocked = true;
236*b1cdbd2cSJim Jagielski             xLayouter->lock();
237*b1cdbd2cSJim Jagielski         }
238*b1cdbd2cSJim Jagielski 
239*b1cdbd2cSJim Jagielski         // As a fallback, when the notification mechanism does not work (or is
240*b1cdbd2cSJim Jagielski         // incorrectly used) we use a timer that will unlock us eventually.
241*b1cdbd2cSJim Jagielski         maTimer.SetTimeout(5000 /*ms*/);
242*b1cdbd2cSJim Jagielski         maTimer.SetTimeoutHdl(LINK(this,UpdateLockManager::Implementation,Timeout));
243*b1cdbd2cSJim Jagielski         maTimer.Start();
244*b1cdbd2cSJim Jagielski     }
245*b1cdbd2cSJim Jagielski }
246*b1cdbd2cSJim Jagielski 
247*b1cdbd2cSJim Jagielski 
248*b1cdbd2cSJim Jagielski 
249*b1cdbd2cSJim Jagielski 
Unlock(void)250*b1cdbd2cSJim Jagielski void UpdateLockManager::Implementation::Unlock (void)
251*b1cdbd2cSJim Jagielski {
252*b1cdbd2cSJim Jagielski     --mnLockDepth;
253*b1cdbd2cSJim Jagielski 
254*b1cdbd2cSJim Jagielski     if (mnLockDepth == 0)
255*b1cdbd2cSJim Jagielski     {
256*b1cdbd2cSJim Jagielski         // Stop the timer.  We don't need it anymore.
257*b1cdbd2cSJim Jagielski         maTimer.Stop();
258*b1cdbd2cSJim Jagielski 
259*b1cdbd2cSJim Jagielski         try
260*b1cdbd2cSJim Jagielski         {
261*b1cdbd2cSJim Jagielski             Reference<frame::XLayoutManager> xLayouter (GetLayoutManager());
262*b1cdbd2cSJim Jagielski             if (xLayouter.is())
263*b1cdbd2cSJim Jagielski             {
264*b1cdbd2cSJim Jagielski                 // Detach from the layouter.
265*b1cdbd2cSJim Jagielski                 if (mbListenerIsRegistered)
266*b1cdbd2cSJim Jagielski                 {
267*b1cdbd2cSJim Jagielski                     Reference<frame::XLayoutManagerEventBroadcaster> xBroadcaster (
268*b1cdbd2cSJim Jagielski                         xLayouter, UNO_QUERY);
269*b1cdbd2cSJim Jagielski                     if (xBroadcaster.is())
270*b1cdbd2cSJim Jagielski                     {
271*b1cdbd2cSJim Jagielski                         mbListenerIsRegistered = false;
272*b1cdbd2cSJim Jagielski                         xBroadcaster->removeLayoutManagerEventListener(
273*b1cdbd2cSJim Jagielski                             Reference<frame::XLayoutManagerListener> (
274*b1cdbd2cSJim Jagielski                                 static_cast<XWeak*>(this), UNO_QUERY) );
275*b1cdbd2cSJim Jagielski                     }
276*b1cdbd2cSJim Jagielski                 }
277*b1cdbd2cSJim Jagielski 
278*b1cdbd2cSJim Jagielski                 // Unlock the layouter.
279*b1cdbd2cSJim Jagielski                 if (mbLayouterIsLocked)
280*b1cdbd2cSJim Jagielski                 {
281*b1cdbd2cSJim Jagielski                     mbLayouterIsLocked = false;
282*b1cdbd2cSJim Jagielski                     xLayouter->unlock();
283*b1cdbd2cSJim Jagielski                 }
284*b1cdbd2cSJim Jagielski             }
285*b1cdbd2cSJim Jagielski         }
286*b1cdbd2cSJim Jagielski         catch (RuntimeException)
287*b1cdbd2cSJim Jagielski         { }
288*b1cdbd2cSJim Jagielski 
289*b1cdbd2cSJim Jagielski         // Force a rearrangement of the UI elements of the views.
290*b1cdbd2cSJim Jagielski         mrBase.Rearrange();
291*b1cdbd2cSJim Jagielski     }
292*b1cdbd2cSJim Jagielski }
293*b1cdbd2cSJim Jagielski 
294*b1cdbd2cSJim Jagielski 
295*b1cdbd2cSJim Jagielski 
296*b1cdbd2cSJim Jagielski 
IsLocked(void) const297*b1cdbd2cSJim Jagielski bool UpdateLockManager::Implementation::IsLocked (void) const
298*b1cdbd2cSJim Jagielski {
299*b1cdbd2cSJim Jagielski     return (mnLockDepth > 0);
300*b1cdbd2cSJim Jagielski }
301*b1cdbd2cSJim Jagielski 
302*b1cdbd2cSJim Jagielski 
303*b1cdbd2cSJim Jagielski 
304*b1cdbd2cSJim Jagielski 
ForceUnlock(void)305*b1cdbd2cSJim Jagielski void UpdateLockManager::Implementation::ForceUnlock (void)
306*b1cdbd2cSJim Jagielski {
307*b1cdbd2cSJim Jagielski     while (IsLocked())
308*b1cdbd2cSJim Jagielski         Unlock();
309*b1cdbd2cSJim Jagielski }
310*b1cdbd2cSJim Jagielski 
311*b1cdbd2cSJim Jagielski 
312*b1cdbd2cSJim Jagielski 
313*b1cdbd2cSJim Jagielski 
layoutEvent(const lang::EventObject &,sal_Int16 eLayoutEvent,const Any & rInfo)314*b1cdbd2cSJim Jagielski void SAL_CALL UpdateLockManager::Implementation::layoutEvent (
315*b1cdbd2cSJim Jagielski     const lang::EventObject&,
316*b1cdbd2cSJim Jagielski     sal_Int16 eLayoutEvent,
317*b1cdbd2cSJim Jagielski     const Any& rInfo)
318*b1cdbd2cSJim Jagielski     throw (uno::RuntimeException)
319*b1cdbd2cSJim Jagielski {
320*b1cdbd2cSJim Jagielski     switch (eLayoutEvent)
321*b1cdbd2cSJim Jagielski     {
322*b1cdbd2cSJim Jagielski         case frame::LayoutManagerEvents::LOCK:
323*b1cdbd2cSJim Jagielski         {
324*b1cdbd2cSJim Jagielski             sal_Int32 nLockCount;
325*b1cdbd2cSJim Jagielski             rInfo >>= nLockCount;
326*b1cdbd2cSJim Jagielski         }
327*b1cdbd2cSJim Jagielski         break;
328*b1cdbd2cSJim Jagielski 
329*b1cdbd2cSJim Jagielski         case frame::LayoutManagerEvents::UNLOCK:
330*b1cdbd2cSJim Jagielski         {
331*b1cdbd2cSJim Jagielski             sal_Int32 nLockCount = 0;
332*b1cdbd2cSJim Jagielski             rInfo >>= nLockCount;
333*b1cdbd2cSJim Jagielski             if (nLockCount == 1)
334*b1cdbd2cSJim Jagielski             {
335*b1cdbd2cSJim Jagielski                 // The lock count dropped to one.  This means that we are
336*b1cdbd2cSJim Jagielski                 // the only one that still holds a lock to the layout
337*b1cdbd2cSJim Jagielski                 // manager.  We unlock the layout manager now and the
338*b1cdbd2cSJim Jagielski                 // ViewShellBase on the next layout of the layout manager.
339*b1cdbd2cSJim Jagielski                 mbUnlockOnNextLayout = true;
340*b1cdbd2cSJim Jagielski                 Reference<frame::XLayoutManager> xLayouter (GetLayoutManager());
341*b1cdbd2cSJim Jagielski                 if (xLayouter.is() && mbLayouterIsLocked)
342*b1cdbd2cSJim Jagielski                 {
343*b1cdbd2cSJim Jagielski                     mbLayouterIsLocked = false;
344*b1cdbd2cSJim Jagielski                     xLayouter->unlock();
345*b1cdbd2cSJim Jagielski                 }
346*b1cdbd2cSJim Jagielski             }
347*b1cdbd2cSJim Jagielski         }
348*b1cdbd2cSJim Jagielski         break;
349*b1cdbd2cSJim Jagielski 
350*b1cdbd2cSJim Jagielski         case frame::LayoutManagerEvents::LAYOUT:
351*b1cdbd2cSJim Jagielski             // Unlock when the layout manager is not still locked.
352*b1cdbd2cSJim Jagielski             if (mbUnlockOnNextLayout)
353*b1cdbd2cSJim Jagielski                 Unlock();
354*b1cdbd2cSJim Jagielski             break;
355*b1cdbd2cSJim Jagielski     }
356*b1cdbd2cSJim Jagielski }
357*b1cdbd2cSJim Jagielski 
358*b1cdbd2cSJim Jagielski 
359*b1cdbd2cSJim Jagielski 
360*b1cdbd2cSJim Jagielski 
disposing(const lang::EventObject &)361*b1cdbd2cSJim Jagielski void SAL_CALL UpdateLockManager::Implementation::disposing (const lang::EventObject& )
362*b1cdbd2cSJim Jagielski     throw (::com::sun::star::uno::RuntimeException)
363*b1cdbd2cSJim Jagielski {
364*b1cdbd2cSJim Jagielski }
365*b1cdbd2cSJim Jagielski 
366*b1cdbd2cSJim Jagielski 
367*b1cdbd2cSJim Jagielski 
368*b1cdbd2cSJim Jagielski 
disposing(void)369*b1cdbd2cSJim Jagielski void SAL_CALL UpdateLockManager::Implementation::disposing (void)
370*b1cdbd2cSJim Jagielski {
371*b1cdbd2cSJim Jagielski }
372*b1cdbd2cSJim Jagielski 
373*b1cdbd2cSJim Jagielski 
374*b1cdbd2cSJim Jagielski 
375*b1cdbd2cSJim Jagielski 
IMPL_LINK(UpdateLockManager::Implementation,Timeout,void *,EMPTYARG)376*b1cdbd2cSJim Jagielski IMPL_LINK(UpdateLockManager::Implementation, Timeout, void*, EMPTYARG)
377*b1cdbd2cSJim Jagielski {
378*b1cdbd2cSJim Jagielski     // This method is only called when all else failed.  We unlock
379*b1cdbd2cSJim Jagielski     // regardless of how deep the lock depth.
380*b1cdbd2cSJim Jagielski     while (mnLockDepth > 0)
381*b1cdbd2cSJim Jagielski         Unlock();
382*b1cdbd2cSJim Jagielski     return 1;
383*b1cdbd2cSJim Jagielski }
384*b1cdbd2cSJim Jagielski 
385*b1cdbd2cSJim Jagielski 
386*b1cdbd2cSJim Jagielski 
387*b1cdbd2cSJim Jagielski 
388*b1cdbd2cSJim Jagielski Reference< ::com::sun::star::frame::XLayoutManager>
GetLayoutManager(void)389*b1cdbd2cSJim Jagielski     UpdateLockManager::Implementation::GetLayoutManager (void)
390*b1cdbd2cSJim Jagielski {
391*b1cdbd2cSJim Jagielski     Reference<frame::XLayoutManager> xLayoutManager;
392*b1cdbd2cSJim Jagielski 
393*b1cdbd2cSJim Jagielski     if (mxLayoutManager.get() == NULL)
394*b1cdbd2cSJim Jagielski     {
395*b1cdbd2cSJim Jagielski         if (mrBase.GetViewFrame()!=NULL)
396*b1cdbd2cSJim Jagielski         {
397*b1cdbd2cSJim Jagielski             Reference<beans::XPropertySet> xFrameProperties (
398*b1cdbd2cSJim Jagielski                 mrBase.GetViewFrame()->GetFrame().GetFrameInterface(),
399*b1cdbd2cSJim Jagielski                 UNO_QUERY);
400*b1cdbd2cSJim Jagielski             if (xFrameProperties.is())
401*b1cdbd2cSJim Jagielski             {
402*b1cdbd2cSJim Jagielski                 try
403*b1cdbd2cSJim Jagielski                 {
404*b1cdbd2cSJim Jagielski                     Any aValue (xFrameProperties->getPropertyValue(
405*b1cdbd2cSJim Jagielski                         ::rtl::OUString::createFromAscii("LayoutManager")));
406*b1cdbd2cSJim Jagielski                     aValue >>= xLayoutManager;
407*b1cdbd2cSJim Jagielski                 }
408*b1cdbd2cSJim Jagielski                 catch (const beans::UnknownPropertyException& rException)
409*b1cdbd2cSJim Jagielski                 {
410*b1cdbd2cSJim Jagielski                     (void)rException;
411*b1cdbd2cSJim Jagielski                 }
412*b1cdbd2cSJim Jagielski             }
413*b1cdbd2cSJim Jagielski             mxLayoutManager = xLayoutManager;
414*b1cdbd2cSJim Jagielski         }
415*b1cdbd2cSJim Jagielski     }
416*b1cdbd2cSJim Jagielski     else
417*b1cdbd2cSJim Jagielski         xLayoutManager = mxLayoutManager;
418*b1cdbd2cSJim Jagielski 
419*b1cdbd2cSJim Jagielski     return xLayoutManager;
420*b1cdbd2cSJim Jagielski }
421*b1cdbd2cSJim Jagielski 
422*b1cdbd2cSJim Jagielski 
423*b1cdbd2cSJim Jagielski 
424*b1cdbd2cSJim Jagielski 
425*b1cdbd2cSJim Jagielski } // end of anonymous namespace
426