Version 5.2.6.1, tag libreoffice-5.2.6.1
[LibreOffice.git] / dbaccess / source / ui / inc / moduledbu.hxx
blobd4e7463eb3019b2e6cb1542d2b1e9b3f1b0d5175
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_DBACCESS_SOURCE_UI_INC_MODULEDBU_HXX
21 #define INCLUDED_DBACCESS_SOURCE_UI_INC_MODULEDBU_HXX
23 #include <osl/mutex.hxx>
24 #include <tools/resid.hxx>
26 class ResMgr;
28 namespace dbaui
31 // OModule
32 class OModuleImpl;
33 class OModule
35 friend class OModuleClient;
37 private:
38 OModule() = delete; //TODO: get rid of this class
40 protected:
41 static ::osl::Mutex s_aMutex; /// access safety
42 static sal_Int32 s_nClients; /// number of registered clients
43 static OModuleImpl* s_pImpl; /// impl class. lives as long as at least one client for the module is registered
45 public:
46 /// get the vcl res manager of the module
47 static ResMgr* getResManager();
49 protected:
50 /// register a client for the module
51 static void registerClient();
52 /// revoke a client for the module
53 static void revokeClient();
55 private:
56 /** ensure that the impl class exists
57 @precond m_aMutex is guarded when this method gets called
59 static void ensureImpl();
62 // OModuleClient
63 /** base class for objects which uses any global module-specific resources
65 class OModuleClient
67 public:
68 OModuleClient() { OModule::registerClient(); }
69 ~OModuleClient() { OModule::revokeClient(); }
72 // ModuleRes
73 /** specialized ResId, using the resource manager provided by the global module
75 class ModuleRes : public ::ResId
77 public:
78 ModuleRes(sal_uInt16 _nId) : ResId(_nId, *OModule::getResManager()) { }
81 } // namespace dbaui
83 #endif // INCLUDED_DBACCESS_SOURCE_UI_INC_MODULEDBU_HXX
85 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */