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 _SVX_TEXT_CHANGED_QUEUE_HXX
29*cdf0e10cSrcweir #define _SVX_TEXT_CHANGED_QUEUE_HXX
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #include <memory>
32*cdf0e10cSrcweir #include <list>
33*cdf0e10cSrcweir #include <algorithm>
34*cdf0e10cSrcweir #include <tools/solar.h>
35*cdf0e10cSrcweir #include <tools/rtti.hxx>
36*cdf0e10cSrcweir 
37*cdf0e10cSrcweir class SfxHint;
38*cdf0e10cSrcweir class SdrHint;
39*cdf0e10cSrcweir class SfxSimpleHint;
40*cdf0e10cSrcweir class TextHint;
41*cdf0e10cSrcweir class SvxViewHint;
42*cdf0e10cSrcweir class SvxEditSourceHint;
43*cdf0e10cSrcweir 
44*cdf0e10cSrcweir namespace accessibility
45*cdf0e10cSrcweir {
46*cdf0e10cSrcweir     /** This class handles the notification events for the
47*cdf0e10cSrcweir         AccessibleTextHelper class.
48*cdf0e10cSrcweir 
49*cdf0e10cSrcweir         For various reasons, we cannot process EditEngine events as
50*cdf0e10cSrcweir         they arrive, but have to queue and handle them in a batch.
51*cdf0e10cSrcweir      */
52*cdf0e10cSrcweir 	class AccessibleTextEventQueue
53*cdf0e10cSrcweir     {
54*cdf0e10cSrcweir     public:
55*cdf0e10cSrcweir         typedef ::std::list< SfxHint* > EventQueue;
56*cdf0e10cSrcweir 
57*cdf0e10cSrcweir         AccessibleTextEventQueue();
58*cdf0e10cSrcweir         ~AccessibleTextEventQueue();
59*cdf0e10cSrcweir 
60*cdf0e10cSrcweir         /// Append event to end of queue
61*cdf0e10cSrcweir         void Append( const SfxHint& rHint );
62*cdf0e10cSrcweir         /// Append event to end of queue
63*cdf0e10cSrcweir         void Append( const SdrHint& rHint );
64*cdf0e10cSrcweir         /// Append event to end of queue
65*cdf0e10cSrcweir         void Append( const SfxSimpleHint& rHint );
66*cdf0e10cSrcweir         /// Append event to end of queue
67*cdf0e10cSrcweir         void Append( const TextHint& rHint );
68*cdf0e10cSrcweir         /// Append event to end of queue
69*cdf0e10cSrcweir         void Append( const SvxViewHint& rHint );
70*cdf0e10cSrcweir         /// Append event to end of queue
71*cdf0e10cSrcweir         void Append( const SvxEditSourceHint& rHint );
72*cdf0e10cSrcweir 
73*cdf0e10cSrcweir         /** Pop first queue element
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir         	return first queue element, ownership transfers to caller
76*cdf0e10cSrcweir         */
77*cdf0e10cSrcweir         ::std::auto_ptr< SfxHint > PopFront();
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir         /** Apply functor to every queue member
80*cdf0e10cSrcweir 
81*cdf0e10cSrcweir         	@param rFunctor
82*cdf0e10cSrcweir             Functor to apply. Functor receives queue element as
83*cdf0e10cSrcweir             parameter: void func( const SfxHint* );
84*cdf0e10cSrcweir         */
85*cdf0e10cSrcweir         template < typename Functor > void ForEach( Functor& rFunctor ) const
86*cdf0e10cSrcweir         {
87*cdf0e10cSrcweir             // #109864# Make sure results are put back into rFunctor
88*cdf0e10cSrcweir             rFunctor = ::std::for_each( maEventQueue.begin(), maEventQueue.end(), rFunctor );
89*cdf0e10cSrcweir         }
90*cdf0e10cSrcweir 
91*cdf0e10cSrcweir         /// Query whether queue is empty
92*cdf0e10cSrcweir         bool IsEmpty() const;
93*cdf0e10cSrcweir 
94*cdf0e10cSrcweir         /// Clear event queue
95*cdf0e10cSrcweir         void Clear();
96*cdf0e10cSrcweir 
97*cdf0e10cSrcweir     private:
98*cdf0e10cSrcweir         EventQueue maEventQueue;
99*cdf0e10cSrcweir     };
100*cdf0e10cSrcweir 
101*cdf0e10cSrcweir } // end of namespace accessibility
102*cdf0e10cSrcweir 
103*cdf0e10cSrcweir #endif /* _SVX_TEXT_CHANGED_QUEUE_HXX */
104