1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: ModuleHelper.hxx,v $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
31 #ifndef FORMULA_MODULE_HELPER_RPT_HXX_
32 #define FORMULA_MODULE_HELPER_RPT_HXX_
34 #include <com/sun/star/lang/XMultiServiceFactory.hpp>
35 #include <tools/resmgr.hxx>
36 #include "formula/formuladllapi.h"
37 //.........................................................................
40 //.........................................................................
41 //=========================================================================
43 //=========================================================================
45 class FORMULA_DLLPUBLIC OModule
47 friend class OModuleClient
;
51 // not implemented. OModule is a static class
54 static ::osl::Mutex s_aMutex
; /// access safety
55 static sal_Int32 s_nClients
; /// number of registered clients
56 static OModuleImpl
* s_pImpl
; /// impl class. lives as long as at least one client for the module is registered
59 /// get the vcl res manager of the module
60 static ResMgr
* getResManager();
62 /// register a client for the module
63 static void registerClient();
64 /// revoke a client for the module
65 static void revokeClient();
68 /** ensure that the impl class exists
69 @precond m_aMutex is guarded when this method gets called
71 static void ensureImpl();
74 //=========================================================================
76 //=========================================================================
77 /** base class for objects which uses any global module-specific ressources
79 class FORMULA_DLLPUBLIC OModuleClient
82 OModuleClient() { OModule::registerClient(); }
83 ~OModuleClient() { OModule::revokeClient(); }
86 //=========================================================================
88 //=========================================================================
89 /** specialized ResId, using the ressource manager provided by the global module
91 class FORMULA_DLLPUBLIC ModuleRes
: public ::ResId
94 ModuleRes(USHORT _nId
) : ResId(_nId
, *OModule::getResManager()) { }
96 //.........................................................................
97 } // namespace formula
98 //.........................................................................
100 #endif // FORMULA_MODULE_HELPER_RPT_HXX_