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_TRANSACTIONMANAGER_HXX_
29*cdf0e10cSrcweir #define __FRAMEWORK_THREADHELP_TRANSACTIONMANAGER_HXX_
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
32*cdf0e10cSrcweir //	my own includes
33*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir #include <threadhelp/inoncopyable.h>
36*cdf0e10cSrcweir #include <threadhelp/itransactionmanager.h>
37*cdf0e10cSrcweir #include <threadhelp/gate.hxx>
38*cdf0e10cSrcweir #include <macros/debug.hxx>
39*cdf0e10cSrcweir 
40*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
41*cdf0e10cSrcweir //	interface includes
42*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
43*cdf0e10cSrcweir #include <com/sun/star/uno/Reference.hxx>
44*cdf0e10cSrcweir #include <com/sun/star/uno/XInterface.hpp>
45*cdf0e10cSrcweir #include <com/sun/star/uno/RuntimeException.hpp>
46*cdf0e10cSrcweir #include <com/sun/star/lang/DisposedException.hpp>
47*cdf0e10cSrcweir 
48*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
49*cdf0e10cSrcweir //	other includes
50*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
51*cdf0e10cSrcweir #include <osl/mutex.hxx>
52*cdf0e10cSrcweir #include <fwidllapi.h>
53*cdf0e10cSrcweir 
54*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
55*cdf0e10cSrcweir //	namespace
56*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
57*cdf0e10cSrcweir 
58*cdf0e10cSrcweir namespace framework{
59*cdf0e10cSrcweir 
60*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
61*cdf0e10cSrcweir //	const
62*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
63*cdf0e10cSrcweir 
64*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
65*cdf0e10cSrcweir //	declarations
66*cdf0e10cSrcweir //_________________________________________________________________________________________________________________
67*cdf0e10cSrcweir 
68*cdf0e10cSrcweir /*-************************************************************************************************************//**
69*cdf0e10cSrcweir     @short          implement a transaction manager to support non breakable interface methods
70*cdf0e10cSrcweir     @descr          Use it to support non breakable interface methods without using any thread
71*cdf0e10cSrcweir                     synchronization like e.g. mutex, rw-lock!
72*cdf0e10cSrcweir                     That protect your code against wrong calls at wrong time ... e.g. calls after disposing an object!
73*cdf0e10cSrcweir                     Use combination of EExceptionMode and ERejectReason to detect rejected requests
74*cdf0e10cSrcweir                     and react for it. You can enable automaticly throwing of exceptions too.
75*cdf0e10cSrcweir 
76*cdf0e10cSrcweir     @implements     ITransactionManager
77*cdf0e10cSrcweir     @base           INonCopyable
78*cdf0e10cSrcweir                     ITransactionManager
79*cdf0e10cSrcweir 
80*cdf0e10cSrcweir     @devstatus      draft
81*cdf0e10cSrcweir *//*-*************************************************************************************************************/
82*cdf0e10cSrcweir class FWI_DLLPUBLIC TransactionManager : public  ITransactionManager
83*cdf0e10cSrcweir                          , private INonCopyable
84*cdf0e10cSrcweir {
85*cdf0e10cSrcweir 	//-------------------------------------------------------------------------------------------------------------
86*cdf0e10cSrcweir 	//	public methods
87*cdf0e10cSrcweir 	//-------------------------------------------------------------------------------------------------------------
88*cdf0e10cSrcweir 	public:
89*cdf0e10cSrcweir 
90*cdf0e10cSrcweir                                    TransactionManager           (                                              );
91*cdf0e10cSrcweir         virtual                    ~TransactionManager          (                                              );
92*cdf0e10cSrcweir         virtual void               setWorkingMode               ( EWorkingMode eMode                           );
93*cdf0e10cSrcweir         virtual EWorkingMode       getWorkingMode               (                                              ) const;
94*cdf0e10cSrcweir         virtual sal_Bool           isCallRejected               ( ERejectReason& eReason                       ) const;
95*cdf0e10cSrcweir         virtual void               registerTransaction          ( EExceptionMode eMode, ERejectReason& eReason ) throw( css::uno::RuntimeException, css::lang::DisposedException );
96*cdf0e10cSrcweir         virtual void               unregisterTransaction        (                                              ) throw( css::uno::RuntimeException, css::lang::DisposedException );
97*cdf0e10cSrcweir 
98*cdf0e10cSrcweir 	//-------------------------------------------------------------------------------------------------------------
99*cdf0e10cSrcweir 	//	private methods
100*cdf0e10cSrcweir 	//-------------------------------------------------------------------------------------------------------------
101*cdf0e10cSrcweir 	private:
102*cdf0e10cSrcweir 
103*cdf0e10cSrcweir         void impl_throwExceptions( EExceptionMode eMode, ERejectReason eReason ) const throw( css::uno::RuntimeException, css::lang::DisposedException );
104*cdf0e10cSrcweir 
105*cdf0e10cSrcweir 	//-------------------------------------------------------------------------------------------------------------
106*cdf0e10cSrcweir 	//	private member
107*cdf0e10cSrcweir 	//-------------------------------------------------------------------------------------------------------------
108*cdf0e10cSrcweir 	private:
109*cdf0e10cSrcweir 
110*cdf0e10cSrcweir         mutable ::osl::Mutex    m_aAccessLock           ;   /// regulate access on internal member of this instance
111*cdf0e10cSrcweir         Gate                    m_aBarrier              ;   /// used to block transactions requests during change or work mode
112*cdf0e10cSrcweir         EWorkingMode            m_eWorkingMode          ;   /// current working mode of object which use this manager (used to reject calls at wrong time)
113*cdf0e10cSrcweir         sal_Int32               m_nTransactionCount     ;   /// every transaction request is registered by this counter
114*cdf0e10cSrcweir 
115*cdf0e10cSrcweir };      //  class TransactionManager
116*cdf0e10cSrcweir 
117*cdf0e10cSrcweir }		//	namespace framework
118*cdf0e10cSrcweir 
119*cdf0e10cSrcweir #endif  //  #ifndef __FRAMEWORK_THREADHELP_TRANSACTIONMANAGER_HXX_
120