bump product version to 4.2.0.1
[LibreOffice.git] / include / comphelper / propagg.hxx
blob62a3d59509c579c757222c911fd433d799870ab4
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_COMPHELPER_PROPAGG_HXX
21 #define INCLUDED_COMPHELPER_PROPAGG_HXX
23 #include <com/sun/star/uno/XAggregation.hpp>
24 #include <comphelper/propstate.hxx>
25 #include <comphelper/comphelperdllapi.h>
27 #include <map>
29 //=========================================================================
30 //= property helper classes
31 //=========================================================================
33 //.........................................................................
34 namespace comphelper
36 //.........................................................................
38 //==================================================================
39 //= OPropertyAccessor
40 //= internal helper class for OPropertyArrayAggregationHelper
41 //==================================================================
42 namespace internal
44 struct OPropertyAccessor
46 sal_Int32 nOriginalHandle;
47 sal_Int32 nPos;
48 bool bAggregate;
50 OPropertyAccessor(sal_Int32 _nOriginalHandle, sal_Int32 _nPos, bool _bAggregate)
51 :nOriginalHandle(_nOriginalHandle) ,nPos(_nPos) ,bAggregate(_bAggregate) { }
52 OPropertyAccessor()
53 :nOriginalHandle(-1) ,nPos(-1) ,bAggregate(false) { }
55 bool operator==(const OPropertyAccessor& rOb) const { return nPos == rOb.nPos; }
56 bool operator <(const OPropertyAccessor& rOb) const { return nPos < rOb.nPos; }
59 typedef std::map< sal_Int32, OPropertyAccessor, ::std::less< sal_Int32 > > PropertyAccessorMap;
60 typedef PropertyAccessorMap::iterator PropertyAccessorMapIterator;
61 typedef PropertyAccessorMap::const_iterator ConstPropertyAccessorMapIterator;
64 //==================================================================
65 /**
66 * used as callback for a OPropertyArrayAggregationHelper
68 class IPropertyInfoService
70 public:
71 /** get the prefered handle for the given property
72 @param _rName the property name
73 @return the handle the property should be refered by, or -1 if there are no
74 preferences for the given property
76 virtual sal_Int32 getPreferedPropertyId(const OUString& _rName) = 0;
78 protected:
79 ~IPropertyInfoService() {}
82 /**
83 * used for implementing an cppu::IPropertyArrayHelper for classes
84 * aggregating property sets
87 #define DEFAULT_AGGREGATE_PROPERTY_ID 10000
88 //------------------------------------------------------------------
89 class COMPHELPER_DLLPUBLIC OPropertyArrayAggregationHelper: public ::cppu::IPropertyArrayHelper
91 friend class OPropertySetAggregationHelper;
92 protected:
94 ::com::sun::star::uno::Sequence< ::com::sun::star::beans::Property> m_aProperties;
95 internal::PropertyAccessorMap m_aPropertyAccessors;
97 public:
98 /** construct the object.
99 @param _rProperties the properties of the object doing the aggregation. These properties
100 are used without any checks, so the caller has to ensure that the names and
101 handles are valid.
102 @param _rAggProperties the properties of the aggregate, usually got via an call to getProperties on the
103 XPropertySetInfo of the aggregate.
104 The names of the properties are used without any checks, so the caller has to ensure
105 that there are no doubles.
106 The handles are stored for later quick access, but the outside-handles the
107 aggregate properties get depend from the following two parameters.
108 @param _pInfoService
109 If not NULL, the object pointed to is used to calc handles which should be used
110 for refering the aggregate's properties from outside.
111 If one of the properties returned from the info service conflict with other handles
112 alread present (e.g. through _rProperties), the property is handled as if -1 was returned.
113 If NULL (or, for a special property, a call to getPreferedPropertyId returns -1),
114 the aggregate property(ies) get a new handle which they can be refered by from outside.
115 @param _nFirstAggregateId
116 if the object is about to create new handles for the aggregate properties, it uses
117 id's ascending from this given id.
118 No checks are made if the handle range determined by _nFirstAggregateId conflicts with other
119 handles within _rProperties.
121 OPropertyArrayAggregationHelper(const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::Property>& _rProperties,
122 const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::Property>& _rAggProperties,
123 IPropertyInfoService* _pInfoService = NULL,
124 sal_Int32 _nFirstAggregateId = DEFAULT_AGGREGATE_PROPERTY_ID);
127 /// inherited from IPropertyArrayHelper
128 virtual sal_Bool SAL_CALL fillPropertyMembersByHandle( OUString* _pPropName, sal_Int16* _pAttributes,
129 sal_Int32 _nHandle) ;
131 /// inherited from IPropertyArrayHelper
132 virtual ::com::sun::star::uno::Sequence< ::com::sun::star::beans::Property> SAL_CALL getProperties();
133 /// inherited from IPropertyArrayHelper
134 virtual ::com::sun::star::beans::Property SAL_CALL getPropertyByName(const OUString& _rPropertyName)
135 throw(::com::sun::star::beans::UnknownPropertyException);
137 /// inherited from IPropertyArrayHelper
138 virtual sal_Bool SAL_CALL hasPropertyByName(const OUString& _rPropertyName) ;
139 /// inherited from IPropertyArrayHelper
140 virtual sal_Int32 SAL_CALL getHandleByName(const OUString & _rPropertyName);
141 /// inherited from IPropertyArrayHelper
142 virtual sal_Int32 SAL_CALL fillHandles( /*out*/sal_Int32* _pHandles, const ::com::sun::star::uno::Sequence< OUString >& _rPropNames );
144 /** returns information about a property of the aggregate.
145 @param _pPropName points to a string to receive the property name. No name is returned if this is NULL.
146 @param _pOriginalHandle points to a sal_Int32 to receive the original property hande. No original handle is returned
147 if this is NULL.
148 @param _nHandle the handle of the property as got by, for instance, fillHandles
150 @return sal_True, if _nHandle marks an aggregate property, otherwise sal_False
152 virtual bool SAL_CALL fillAggregatePropertyInfoByHandle(OUString* _pPropName, sal_Int32* _pOriginalHandle,
153 sal_Int32 _nHandle) const;
155 /** returns information about a property given by handle
157 sal_Bool getPropertyByHandle( sal_Int32 _nHandle, ::com::sun::star::beans::Property& _rProperty ) const;
160 enum PropertyOrigin
162 AGGREGATE_PROPERTY,
163 DELEGATOR_PROPERTY,
164 UNKNOWN_PROPERTY
166 /** prefer this one over the XPropertySetInfo of the aggregate!
168 <p>The reason is that OPropertyArrayAggregationHelper is the only instance which really knows
169 which properties of the aggregate are to be exposed. <br/>
171 For instance, some derivee of OPropertySetAggregationHelper may decide to create an
172 OPropertyArrayAggregationHelper which contains only a subset of the aggregate properties. This way,
173 some of the aggregate properties may be hidded to the public.<br/>
175 When using the XPropertySetInfo of the aggregate set to determine the existence of a property, then this
176 would return false positives.</p>
178 PropertyOrigin classifyProperty( const OUString& _rName );
180 protected:
181 const ::com::sun::star::beans::Property* findPropertyByName(const OUString& _rName) const;
184 //==================================================================
185 namespace internal
187 class PropertyForwarder;
191 * helper class for implementing the property-set-related interfaces
192 * for an object doin' aggregation
193 * supports at least XPropertySet and XMultiPropertySet
196 class COMPHELPER_DLLPUBLIC OPropertySetAggregationHelper :public OPropertyStateHelper
197 ,public ::com::sun::star::beans::XPropertiesChangeListener
198 ,public ::com::sun::star::beans::XVetoableChangeListener
200 friend class internal::PropertyForwarder;
202 protected:
203 ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertyState> m_xAggregateState;
204 ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> m_xAggregateSet;
205 ::com::sun::star::uno::Reference< ::com::sun::star::beans::XMultiPropertySet> m_xAggregateMultiSet;
206 ::com::sun::star::uno::Reference< ::com::sun::star::beans::XFastPropertySet> m_xAggregateFastSet;
208 internal::PropertyForwarder* m_pForwarder;
209 sal_Bool m_bListening : 1;
211 public:
212 OPropertySetAggregationHelper( ::cppu::OBroadcastHelper& rBHelper );
214 virtual ::com::sun::star::uno::Any SAL_CALL queryInterface(const ::com::sun::star::uno::Type& aType) throw(::com::sun::star::uno::RuntimeException);
216 // XEventListener
217 virtual void SAL_CALL disposing(const ::com::sun::star::lang::EventObject& Source) throw (::com::sun::star::uno::RuntimeException);
219 // XFastPropertySet
220 virtual void SAL_CALL setFastPropertyValue(sal_Int32 nHandle, const ::com::sun::star::uno::Any& aValue) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
221 virtual ::com::sun::star::uno::Any SAL_CALL getFastPropertyValue(sal_Int32 nHandle) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
223 // XPropertySet
224 virtual void SAL_CALL addPropertyChangeListener(const OUString& aPropertyName, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertyChangeListener >& xListener) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
225 virtual void SAL_CALL addVetoableChangeListener(const OUString& PropertyName, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XVetoableChangeListener >& aListener) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
227 // XPropertiesChangeListener
228 virtual void SAL_CALL propertiesChange(const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyChangeEvent >& evt) throw(::com::sun::star::uno::RuntimeException);
230 // XVetoableChangeListener
231 virtual void SAL_CALL vetoableChange(const ::com::sun::star::beans::PropertyChangeEvent& aEvent) throw(::com::sun::star::beans::PropertyVetoException, ::com::sun::star::uno::RuntimeException);
233 // XMultiPropertySet
234 virtual void SAL_CALL setPropertyValues(const ::com::sun::star::uno::Sequence< OUString >& PropertyNames, const ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any >& Values) throw(::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
235 virtual void SAL_CALL addPropertiesChangeListener(const ::com::sun::star::uno::Sequence< OUString >& aPropertyNames, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertiesChangeListener >& xListener) throw(::com::sun::star::uno::RuntimeException);
237 // XPropertyState
238 virtual ::com::sun::star::beans::PropertyState SAL_CALL getPropertyState(const OUString& PropertyName) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::uno::RuntimeException);
239 virtual void SAL_CALL setPropertyToDefault(const OUString& PropertyName) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::uno::RuntimeException);
240 virtual ::com::sun::star::uno::Any SAL_CALL getPropertyDefault(const OUString& aPropertyName) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
242 // OPropertySetHelper
243 /** still waiting to be overwritten ...
244 you <B>must<B/> use an OPropertyArrayAggregationHelper here, as the implementation strongly relies on this.
246 virtual ::cppu::IPropertyArrayHelper& SAL_CALL getInfoHelper() = 0;
248 /** only implemented for "forwarded" properties, every other property must be handled
249 in the derivee, and will assert if passed herein
251 virtual sal_Bool SAL_CALL convertFastPropertyValue( ::com::sun::star::uno::Any& _rConvertedValue, ::com::sun::star::uno::Any& _rOldValue, sal_Int32 _nHandle, const ::com::sun::star::uno::Any& _rValue ) throw(::com::sun::star::lang::IllegalArgumentException);
253 /** only implemented for "forwarded" properties, every other property must be handled
254 in the derivee, and will assert if passed herein
256 virtual void SAL_CALL setFastPropertyValue_NoBroadcast( sal_Int32 _nHandle, const ::com::sun::star::uno::Any& _rValue ) throw ( ::com::sun::star::uno::Exception );
258 protected:
259 ~OPropertySetAggregationHelper();
261 virtual void SAL_CALL getFastPropertyValue(::com::sun::star::uno::Any& rValue, sal_Int32 nHandle) const;
262 virtual void SAL_CALL disposing();
264 sal_Int32 getOriginalHandle( sal_Int32 _nHandle ) const;
265 OUString getPropertyName( sal_Int32 _nHandle ) const;
267 /** declares the property with the given (public) handle as one to be forwarded to the aggregate
269 Sometimes, you might want to <em>overwrite</em> properties at the aggregate. That is,
270 though the aggregate implements this property, and still is to hold the property value,
271 you want to do additional handling upon setting the property, but then forward the value
272 to the aggregate.
274 Use this method to declare such properties.
276 When a "forwarded property" is set from outside, the class first calls
277 <member>forwardingPropertyValue</member> for any preprocessing, then forwards the property
278 value to the aggregate, and then calls <member>forwardedPropertyValue</member>.
280 When you declare a property as "forwarded", the class takes care for some multi-threading
281 issues, for instance, it won't fire any property change notifications which result from
282 forwarding a property value, unless it's safe to do so (i.e. unless our mutex is
283 released).
285 @see forwardingPropertyValue
286 @see forwardedPropertyValue
288 void declareForwardedProperty( sal_Int32 _nHandle );
290 /** checks whether we're actually forwarding a property value to our aggregate
292 @see declareForwardedProperty
293 @see forwardingPropertyValue
294 @see forwardedPropertyValue
296 bool isCurrentlyForwardingProperty( sal_Int32 _nHandle ) const;
298 /** called immediately before a property value which is overwritten in this instance
299 is forwarded to the aggregate
301 @see declareForwardedProperty
302 @see forwardedPropertyValue
304 virtual void SAL_CALL forwardingPropertyValue( sal_Int32 _nHandle );
306 /** called immediately after a property value which is overwritten in this instance
307 has been forwarded to the aggregate
309 @see declareForwardedProperty
310 @see forwardingPropertyValue
312 virtual void SAL_CALL forwardedPropertyValue( sal_Int32 _nHandle, bool _bSuccess );
314 /// must be called before aggregation, if aggregation is used
315 void setAggregation(const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >&) throw( ::com::sun::star::lang::IllegalArgumentException );
316 void startListening();
319 //.........................................................................
320 } // namespace comphelper
321 //.........................................................................
323 #endif // INCLUDED_COMPHELPER_PROPAGG_HXX
325 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */