1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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 _UTL_CONFIGITEM_HXX_
21 #define _UTL_CONFIGITEM_HXX_
23 #include <sal/types.h>
24 #include <rtl/ustring.hxx>
25 #include <com/sun/star/uno/Sequence.h>
26 #include <com/sun/star/uno/Reference.h>
27 #include "unotools/unotoolsdllapi.h"
28 #include "unotools/options.hxx"
30 //-----------------------------------------------------------------------------
31 namespace com
{ namespace sun
{ namespace star
{
39 class XHierarchicalNameAccess
;
42 class XChangesListener
;
45 //-----------------------------------------------------------------------------
48 #define CONFIG_MODE_IMMEDIATE_UPDATE 0x00
49 #define CONFIG_MODE_DELAYED_UPDATE 0x01
50 #define CONFIG_MODE_ALL_LOCALES 0x02
51 #define CONFIG_MODE_RELEASE_TREE 0x04
55 CONFIG_NAME_PLAINTEXT_NAME
, // unescaped local node name, for user display etc.
56 CONFIG_NAME_LOCAL_NAME
, // local node name, for use in XNameAccess etc. ("Item", "Q & A")
57 CONFIG_NAME_LOCAL_PATH
, // one-level relative path, for use when building paths etc. ("Item", "Typ['Q & A']")
58 CONFIG_NAME_FULL_PATH
, // full absolute path. ("/org.openoffice.Sample/Group/Item", "/org.openoffice.Sample/Set/Typ['Q & A']")
60 CONFIG_NAME_DEFAULT
= CONFIG_NAME_LOCAL_PATH
// default format
63 class ConfigChangeListener_Impl
;
65 struct ConfigItem_Impl
;
67 class UNOTOOLS_DLLPUBLIC ConfigItem
: public ConfigurationBroadcaster
69 friend class ConfigChangeListener_Impl
;
70 friend class ConfigManager
;
72 const OUString sSubTree
;
73 com::sun::star::uno::Reference
< com::sun::star::container::XHierarchicalNameAccess
>
75 com::sun::star::uno::Reference
< com::sun::star::util::XChangesListener
>
77 ConfigItem_Impl
* pImpl
;
80 void RemoveChangesListener();
82 const com::sun::star::uno::Sequence
<OUString
>& aPropertyNames
);
84 //***********************************************************************************************************************
85 // In special mode ALL_LOCALES we must support reading/writing of localized cfg entries as Sequence< PropertyValue >.
86 // These methods are helper to convert given lists of names and Any-values.
87 // format: PropertyValue.Name = <locale as ISO string>
88 // PropertyValue.Value = <value; type depends from cfg entry!>
95 void impl_packLocalizedProperties ( const com::sun::star::uno::Sequence
< OUString
>& lInNames
,
96 const com::sun::star::uno::Sequence
< com::sun::star::uno::Any
>& lInValues
,
97 com::sun::star::uno::Sequence
< com::sun::star::uno::Any
>& lOutValues
);
98 void impl_unpackLocalizedProperties ( const com::sun::star::uno::Sequence
< OUString
>& lInNames
,
99 const com::sun::star::uno::Sequence
< com::sun::star::uno::Any
>& lInValues
,
100 com::sun::star::uno::Sequence
< OUString
>& lOutNames
,
101 com::sun::star::uno::Sequence
< com::sun::star::uno::Any
>& lOutValues
);
103 com::sun::star::uno::Reference
< com::sun::star::container::XHierarchicalNameAccess
>
107 explicit ConfigItem(const OUString
&rSubTree
,
108 sal_Int16 nMode
= CONFIG_MODE_DELAYED_UPDATE
);
110 void SetModified (); // mark item as modified
111 void ClearModified(); // reset state after commit!
113 com::sun::star::uno::Sequence
< com::sun::star::uno::Any
>
114 GetProperties(const com::sun::star::uno::Sequence
< OUString
>& rNames
);
116 com::sun::star::uno::Sequence
< sal_Bool
>
117 GetReadOnlyStates(const com::sun::star::uno::Sequence
< OUString
>& rNames
);
119 sal_Bool
PutProperties(
120 const com::sun::star::uno::Sequence
< OUString
>& rNames
,
121 const com::sun::star::uno::Sequence
< com::sun::star::uno::Any
>& rValues
);
123 /** enables notifications about changes on selected sub nodes/values
125 Before calling this method a second time for a possibly changed node/value set,
126 you must disable the current notifications by calling DisableNotification.
129 @see DisableNotification
131 sal_Bool
EnableNotification(const com::sun::star::uno::Sequence
< OUString
>& rNames
,
132 sal_Bool bEnableInternalNotification
= sal_False
);
133 /** disables notifications about changes on sub nodes/values, which previosly had
134 been enabled with EnableNotification
136 @see EnableNotification
138 void DisableNotification();
139 sal_Bool
IsInternalNotification()const {return IsInValueChange();}
141 //returns all members of a node in a specific format
142 com::sun::star::uno::Sequence
< OUString
>
143 GetNodeNames(const OUString
& rNode
);
144 //returns all members of a node in a specific format
145 com::sun::star::uno::Sequence
< OUString
>
146 GetNodeNames(const OUString
& rNode
, ConfigNameFormat eFormat
);
147 // remove all members of a set
148 sal_Bool
ClearNodeSet(const OUString
& rNode
);
149 // remove selected members of a set
150 sal_Bool
ClearNodeElements(const OUString
& rNode
,
151 com::sun::star::uno::Sequence
< OUString
>& rElements
);
152 // change or add members to a set
153 sal_Bool
SetSetProperties(const OUString
& rNode
, com::sun::star::uno::Sequence
< com::sun::star::beans::PropertyValue
> rValues
);
154 // remove, change or add members of a set
155 sal_Bool
ReplaceSetProperties(const OUString
& rNode
, com::sun::star::uno::Sequence
< com::sun::star::beans::PropertyValue
> rValues
);
156 // add a new node without setting any properties
157 sal_Bool
AddNode(const OUString
& rNode
, const OUString
& rNewNode
);
159 /** get a name for a new element of a set node
161 relative path to the set node
163 <ul><li><b>in</b>: the base to use when calculating a new name</li>
164 <li><b>out</b>: an unused element name</li>
166 @return <TRUE/> if a free name could be generated
168 sal_Bool
getUniqueSetElementName( const OUString
& _rSetNode
, OUString
& _rBaseName
);
171 virtual ~ConfigItem();
173 /** is called from the ConfigManager before application ends of from the
174 PropertyChangeListener if the sub tree broadcasts changes. */
175 virtual void Notify( const com::sun::star::uno::Sequence
<OUString
>& aPropertyNames
)=0;
177 const OUString
& GetSubTreeName() const {return sSubTree
;}
179 sal_Bool
IsModified() const;
181 /** writes the changed values into the sub tree. Always called in the Dtor of the derived class. */
182 virtual void Commit()=0;
184 sal_Bool
IsInValueChange() const;
186 sal_Int16
GetMode() const;
188 /** checks if the configuration manager used by this item is valid.
190 sal_Bool
IsValidConfigMgr() const;
193 #endif //_UTL_CONFIGITEM_HXX_
195 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */