build fix: no comphelper/profilezone.hxx in this branch
[LibreOffice.git] / dbaccess / source / core / inc / definitioncontainer.hxx
blob4d32d20557207618b239a8060d3141de9f5f9d6f
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_CORE_INC_DEFINITIONCONTAINER_HXX
21 #define INCLUDED_DBACCESS_SOURCE_CORE_INC_DEFINITIONCONTAINER_HXX
23 #include <sal/config.h>
25 #include <map>
26 #include <vector>
28 #include <cppuhelper/interfacecontainer.hxx>
29 #include <cppuhelper/implbase7.hxx>
30 #include <osl/mutex.hxx>
31 #include <com/sun/star/container/XChild.hpp>
32 #include <com/sun/star/container/XNameContainer.hpp>
33 #include <com/sun/star/container/XContainer.hpp>
34 #include <com/sun/star/container/XEnumerationAccess.hpp>
35 #include <com/sun/star/container/XIndexAccess.hpp>
36 #include <com/sun/star/lang/XServiceInfo.hpp>
37 #include <com/sun/star/lang/DisposedException.hpp>
38 #include <com/sun/star/beans/XPropertyChangeListener.hpp>
39 #include <com/sun/star/beans/XVetoableChangeListener.hpp>
40 #include <com/sun/star/container/XContainerApproveBroadcaster.hpp>
41 #include "ContentHelper.hxx"
42 #include "containerapprove.hxx"
43 #include <comphelper/uno3.hxx>
44 #include <rtl/ref.hxx>
45 #include "apitools.hxx"
47 namespace dbaccess
50 class ODefinitionContainer_Impl : public OContentHelper_Impl
52 public:
53 typedef ::std::map< OUString, TContentPtr > NamedDefinitions;
54 typedef NamedDefinitions::iterator iterator;
55 typedef NamedDefinitions::const_iterator const_iterator;
57 private:
58 NamedDefinitions m_aDefinitions;
60 public:
61 inline size_t size() const { return m_aDefinitions.size(); }
63 inline const_iterator begin() const { return m_aDefinitions.begin(); }
64 inline const_iterator end() const { return m_aDefinitions.end(); }
66 inline const_iterator find( const OUString& _rName ) const { return m_aDefinitions.find( _rName ); }
67 const_iterator find( const TContentPtr& _pDefinition ) const;
69 inline void erase( const OUString& _rName ) { m_aDefinitions.erase( _rName ); }
70 void erase( const TContentPtr& _pDefinition );
72 inline void insert( const OUString& _rName, TContentPtr _pDefinition )
74 m_aDefinitions.insert( NamedDefinitions::value_type( _rName, _pDefinition ) );
77 private:
78 iterator find( const TContentPtr& _pDefinition );
79 // (for the moment, this is private. Make it public if needed. If really needed.)
82 // ODefinitionContainer - base class of collections of database definition
83 // documents
84 typedef ::cppu::ImplHelper7 < css::container::XIndexAccess
85 , css::container::XNameContainer
86 , css::container::XEnumerationAccess
87 , css::container::XContainer
88 , css::container::XContainerApproveBroadcaster
89 , css::beans::XPropertyChangeListener
90 , css::beans::XVetoableChangeListener
91 > ODefinitionContainer_Base;
93 class ODefinitionContainer
94 :public OContentHelper
95 ,public ODefinitionContainer_Base
97 protected:
98 typedef std::map< OUString, css::uno::WeakReference< css::ucb::XContent > > Documents;
99 typedef std::vector<Documents::iterator> DocumentsIndexAccess;
101 enum ContainerOperation
103 E_REPLACED,
104 E_REMOVED,
105 E_INSERTED
108 enum ListenerType
110 ApproveListeners,
111 ContainerListemers
114 private:
115 PContainerApprove m_pElementApproval;
117 protected:
118 // we can't just hold a vector of XContentRefs, as after initialization they're all empty
119 // cause we load them only on access
120 DocumentsIndexAccess m_aDocuments; // for a efficient index access
121 Documents m_aDocumentMap; // for a efficient name access
123 ::comphelper::OInterfaceContainerHelper2
124 m_aApproveListeners;
125 ::comphelper::OInterfaceContainerHelper2
126 m_aContainerListeners;
128 bool m_bInPropertyChange;
129 bool m_bCheckSlash;
131 protected:
132 /** Additionally to our own approvals which new elements must pass, derived classes
133 can specifiy an additional approval instance here.
135 Every time a new element is inserted into the container (or an element is replaced
136 with a new one), this new element must pass our own internal approval, plus the approval
137 given here.
139 void setElementApproval( PContainerApprove _pElementApproval ) { m_pElementApproval = _pElementApproval; }
140 const PContainerApprove& getElementApproval() const { return m_pElementApproval; }
142 protected:
143 virtual ~ODefinitionContainer() override;
145 inline const ODefinitionContainer_Impl& getDefinitions() const
147 return dynamic_cast< const ODefinitionContainer_Impl& >( *m_pImpl.get() );
150 inline ODefinitionContainer_Impl& getDefinitions()
152 return dynamic_cast< ODefinitionContainer_Impl& >( *m_pImpl.get() );
154 public:
155 /** constructs the container.
157 ODefinitionContainer(
158 const css::uno::Reference< css::uno::XComponentContext >& _xORB
159 , const css::uno::Reference< css::uno::XInterface >& _xParentContainer
160 , const TContentPtr& _pImpl
161 , bool _bCheckSlash = true
164 // css::uno::XInterface
165 DECLARE_XINTERFACE( )
167 virtual css::uno::Sequence<css::uno::Type> SAL_CALL getTypes()
168 throw (css::uno::RuntimeException, std::exception) override;
169 virtual css::uno::Sequence<sal_Int8> SAL_CALL getImplementationId()
170 throw (css::uno::RuntimeException, std::exception) override;
172 // css::lang::XServiceInfo
173 virtual OUString SAL_CALL getImplementationName( ) throw(css::uno::RuntimeException, std::exception) override;
174 virtual css::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames( ) throw(css::uno::RuntimeException, std::exception) override;
176 // css::container::XElementAccess
177 virtual css::uno::Type SAL_CALL getElementType( ) throw(css::uno::RuntimeException, std::exception) override;
178 virtual sal_Bool SAL_CALL hasElements( ) throw(css::uno::RuntimeException, std::exception) override;
180 // css::container::XEnumerationAccess
181 virtual css::uno::Reference< css::container::XEnumeration > SAL_CALL createEnumeration( ) throw(css::uno::RuntimeException, std::exception) override;
183 // css::container::XIndexAccess
184 virtual sal_Int32 SAL_CALL getCount( ) throw(css::uno::RuntimeException, std::exception) override;
185 virtual css::uno::Any SAL_CALL getByIndex( sal_Int32 _nIndex ) throw(css::lang::IndexOutOfBoundsException, css::lang::WrappedTargetException, css::uno::RuntimeException, std::exception) override;
187 // css::container::XNameContainer
188 virtual void SAL_CALL insertByName( const OUString& _rName, const css::uno::Any& aElement ) throw(css::lang::IllegalArgumentException, css::container::ElementExistException, css::lang::WrappedTargetException, css::uno::RuntimeException, std::exception) override;
189 virtual void SAL_CALL removeByName( const OUString& _rName ) throw(css::container::NoSuchElementException, css::lang::WrappedTargetException, css::uno::RuntimeException, std::exception) override;
191 // css::container::XNameReplace
192 virtual void SAL_CALL replaceByName( const OUString& _rName, const css::uno::Any& aElement ) throw(css::lang::IllegalArgumentException, css::container::NoSuchElementException, css::lang::WrappedTargetException, css::uno::RuntimeException, std::exception) override;
194 // css::container::XNameAccess
195 virtual css::uno::Any SAL_CALL getByName( const OUString& aName ) throw(css::container::NoSuchElementException, css::lang::WrappedTargetException, css::uno::RuntimeException, std::exception) override;
196 virtual css::uno::Sequence< OUString > SAL_CALL getElementNames( ) throw(css::uno::RuntimeException, std::exception) override;
197 virtual sal_Bool SAL_CALL hasByName( const OUString& aName ) throw(css::uno::RuntimeException, std::exception) override;
199 // css::container::XContainer
200 virtual void SAL_CALL addContainerListener( const css::uno::Reference< css::container::XContainerListener >& xListener ) throw(css::uno::RuntimeException, std::exception) override;
201 virtual void SAL_CALL removeContainerListener( const css::uno::Reference< css::container::XContainerListener >& xListener ) throw(css::uno::RuntimeException, std::exception) override;
203 // XContainerApproveBroadcaster
204 virtual void SAL_CALL addContainerApproveListener( const css::uno::Reference< css::container::XContainerApproveListener >& Listener ) throw (css::uno::RuntimeException, std::exception) override;
205 virtual void SAL_CALL removeContainerApproveListener( const css::uno::Reference< css::container::XContainerApproveListener >& Listener ) throw (css::uno::RuntimeException, std::exception) override;
207 // css::lang::XEventListener
208 virtual void SAL_CALL disposing( const css::lang::EventObject& Source ) throw(css::uno::RuntimeException, std::exception) override;
210 // XPropertyChangeListener
211 virtual void SAL_CALL propertyChange( const css::beans::PropertyChangeEvent& evt ) throw (css::uno::RuntimeException, std::exception) override;
212 // XVetoableChangeListener
213 virtual void SAL_CALL vetoableChange( const css::beans::PropertyChangeEvent& aEvent ) throw (css::beans::PropertyVetoException, css::uno::RuntimeException, std::exception) override;
215 protected:
216 // helper
217 virtual void SAL_CALL disposing() override;
219 /** create a object from its persistent data within the configuration. To be overwritten by derived classes.
220 @param _rName the name the object has within the container
221 @return the newly created object or an empty reference if something went wrong
223 virtual css::uno::Reference< css::ucb::XContent > createObject(
224 const OUString& _rName) = 0;
226 /** get the object specified by the given name. If desired, the object will be read if not already done so.<BR>
227 @param _rName the object name
228 @param _bReadIfNecessary if sal_True, the object will be created if necessary
229 @return the property set interface of the object. Usually the return value is not NULL, but
230 if so, then the object could not be read from the configuration
231 @throws NoSuchElementException if there is no object with the given name.
232 @see createObject
234 css::uno::Reference< css::ucb::XContent >
235 implGetByName(const OUString& _rName, bool _bCreateIfNecessary) throw (css::container::NoSuchElementException);
237 /** quickly checks if there already is an element with a given name. No access to the configuration occurs, i.e.
238 if there is such an object which is not already loaded, it won't be loaded now.
239 @param _rName the object name to check
240 @return sal_True if there already exists such an object
242 virtual bool checkExistence(const OUString& _rName);
244 /** append a new object to the container. No plausibility checks are done, e.g. if the object is non-NULL or
245 if the name is already used by another object or anything like this. This method is for derived classes
246 which may support different methods to create and/or append objects, and don't want to deal with the
247 internal structures of this class.<BR>
248 The old component will not be disposed, this is the callers responsibility, too.
249 @param _rName the name of the new object
250 @param _rxNewObject the new object (not surprising, is it ?)
251 @see createConfigKey
252 @see implReplace
253 @see implRemove
255 void implAppend(
256 const OUString& _rName,
257 const css::uno::Reference< css::ucb::XContent >& _rxNewObject
260 /** remove all references to an object from the container. No plausibility checks are done, e.g. whether
261 or not there exists an object with the given name. This is the responsibility of the caller.<BR>
262 Additionally the node for the given object will be removed from the registry (including all sub nodes).<BR>
263 The old component will not be disposed, this is the callers responsibility, too.
264 @param _rName the objects name
265 @see implReplace
266 @see implAppend
268 void implRemove(const OUString& _rName);
270 /** remove a object in the container. No plausibility checks are done, e.g. whether
271 or not there exists an object with the given name or the object is non-NULL. This is the responsibility of the caller.<BR>
272 Additionally all object-related information within the registry will be deleted. The new object config node,
273 where the caller may want to store the new objects information, is returned.<BR>
274 The old component will not be disposed, this is the callers responsibility, too.
275 @param _rName the objects name
276 @param _rxNewObject the new object
277 @param _rNewObjectNode the configuration node where the new object may be stored
278 @see implAppend
279 @see implRemove
281 void implReplace(
282 const OUString& _rName,
283 const css::uno::Reference< css::ucb::XContent >& _rxNewObject
286 /** notifies our container/approve listeners
288 void notifyByName(
289 ::osl::ResettableMutexGuard& _rGuard,
290 const OUString& _rName,
291 const css::uno::Reference< css::ucb::XContent >& _xNewElement,
292 const css::uno::Reference< css::ucb::XContent >& xOldElement,
293 ContainerOperation _eOperation,
294 ListenerType _eType
297 inline SAL_CALL operator css::uno::Reference< css::uno::XInterface > () const
299 return const_cast< XContainer* >( static_cast< const XContainer* >( this ) );
302 private:
303 void addObjectListener(const css::uno::Reference< css::ucb::XContent >& _xNewObject);
304 void removeObjectListener(const css::uno::Reference< css::ucb::XContent >& _xNewObject);
306 /** approve that the object given may be inserted into the container.
307 Should be overridden by derived classes,
308 the default implementation just checks the object to be non-void.
310 @throws IllegalArgumentException
311 if the name or the object are invalid
312 @throws ElementExistException
313 if the object already exists in the container, or another object with the same name
314 already exists
315 @throws WrappedTargetException
316 if another error occurs which prevents insertion of the object into the container
318 void approveNewObject(
319 const OUString& _sName,
320 const css::uno::Reference< css::ucb::XContent >& _rxObject
321 ) const;
323 inline bool impl_haveAnyListeners_nothrow() const
325 return ( m_aContainerListeners.getLength() > 0 ) || ( m_aApproveListeners.getLength() > 0 );
329 } // namespace dbaccess
331 #endif // INCLUDED_DBACCESS_SOURCE_CORE_INC_DEFINITIONCONTAINER_HXX
333 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */