nss: upgrade to release 3.73
[LibreOffice.git] / include / svx / shapepropertynotifier.hxx
blobbdef4e11e7b8e148606530477935ffcf6f7c0f0a
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_SVX_SHAPEPROPERTYNOTIFIER_HXX
21 #define INCLUDED_SVX_SHAPEPROPERTYNOTIFIER_HXX
23 #include <svx/svxdllapi.h>
24 #include <svx/shapeproperty.hxx>
25 #include <rtl/ustring.hxx>
27 #include <memory>
29 namespace com::sun::star::beans { class XPropertyChangeListener; }
30 namespace com::sun::star::uno { class Any; }
31 namespace com::sun::star::uno { template <typename > class Reference; }
32 namespace osl { class Mutex; }
34 namespace cppu
36 class OWeakObject;
40 namespace svx
44 //= IPropertyValueProvider
46 /** a provider for a property value
48 class SVXCORE_DLLPUBLIC IPropertyValueProvider
50 public:
51 /** returns the name of the property which this provider is responsible for
53 virtual OUString getPropertyName() const = 0;
55 /** returns the current value of the property which the provider is responsible for
57 virtual void getCurrentValue( css::uno::Any& _out_rValue ) const = 0;
59 virtual ~IPropertyValueProvider();
62 //= PropertyValueProvider
64 /** default implementation of an IPropertyValueProvider
66 This default implementation queries the object which it is constructed with for the XPropertySet interface,
67 and calls the getPropertyValue method.
69 class SVXCORE_DLLPUBLIC PropertyValueProvider :public IPropertyValueProvider
71 public:
72 PropertyValueProvider( ::cppu::OWeakObject& _rContext, const char* _pAsciiPropertyName )
73 :m_rContext( _rContext )
74 ,m_sPropertyName( OUString::createFromAscii( _pAsciiPropertyName ) )
78 virtual OUString getPropertyName() const override;
79 virtual void getCurrentValue( css::uno::Any& _out_rValue ) const override;
81 protected:
82 ::cppu::OWeakObject& getContext() const { return m_rContext; }
83 PropertyValueProvider(const PropertyValueProvider&) = delete;
84 PropertyValueProvider& operator=(const PropertyValueProvider&) = delete;
86 private:
87 ::cppu::OWeakObject& m_rContext;
88 const OUString m_sPropertyName;
92 //= PropertyChangeNotifier
94 struct PropertyChangeNotifier_Data;
96 /** helper class for notifying XPropertyChangeListeners
98 The class is intended to be held as member of the class which does the property change broadcasting.
100 class SVXCORE_DLLPUBLIC PropertyChangeNotifier
102 public:
103 /** constructs a notifier instance
105 @param _rOwner
106 the owner instance of the notifier. Will be used as css.lang.EventObject.Source when
107 notifying events.
109 PropertyChangeNotifier( ::cppu::OWeakObject& _rOwner, ::osl::Mutex& _rMutex );
110 ~PropertyChangeNotifier();
112 // listener maintenance
113 void addPropertyChangeListener( const OUString& _rPropertyName, const css::uno::Reference< css::beans::XPropertyChangeListener >& _rxListener );
114 void removePropertyChangeListener( const OUString& _rPropertyName, const css::uno::Reference< css::beans::XPropertyChangeListener >& _rxListener );
116 /** registers an IPropertyValueProvider
118 void registerProvider( const ShapeProperty _eProperty, const std::shared_ptr<IPropertyValueProvider>& _rProvider );
120 /** notifies changes in the given property to all registered listeners
122 If no property value provider for the given property ID is registered, this is worth an assertion in a
123 non-product build, and otherwise ignored.
125 void notifyPropertyChange( const ShapeProperty _eProperty ) const;
127 /** is called to dispose the instance
129 void disposing();
131 private:
132 PropertyChangeNotifier(const PropertyChangeNotifier&) = delete;
133 PropertyChangeNotifier& operator=(const PropertyChangeNotifier&) = delete;
135 std::unique_ptr< PropertyChangeNotifier_Data > m_xData;
142 #endif // INCLUDED_SVX_SHAPEPROPERTYNOTIFIER_HXX
144 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */