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 .
22 #include <sal/config.h>
24 #include <string_view>
26 #include <accelerators/storageholder.hxx>
28 #include <com/sun/star/embed/XStorage.hpp>
30 #include <com/sun/star/uno/XComponentContext.hpp>
32 #include <i18nlangtag/languagetag.hxx>
39 <layer>/global/<resourcetype>/<preset>.xml
40 <layer>/modules/<moduleid>/<resourcetype>/<preset>.xml
42 RESOURCETYPE PRESET TARGET
44 "accelerator" "default" "current"
48 "menubar" "default" "menubar"
55 /** @short this handler can provide different
56 types of configuration.
58 @descr Means: a global or a module dependent
70 /** @short can be used to create on needed uno resources. */
71 css::uno::Reference
< css::uno::XComponentContext
> m_xContext
;
73 /** @short knows the type of provided configuration.
75 @descr e.g. global, modules, ...
77 EConfigType m_eConfigType
;
79 /** @short if we run in document mode, we can't use the global root storages!
80 We have to use a special document storage explicitly. */
81 StorageHolder m_lDocumentStorages
;
83 /** @short holds the folder storage of the share layer alive,
84 where the current configuration set exists.
86 @descr Note: If this preset handler works in document mode
87 this member is meant relative to the document root...
88 not to the share layer root!
90 Further is defined, that m_xWorkingStorageUser
91 is equals to m_xWorkingStorageShare then!
93 css::uno::Reference
< css::embed::XStorage
> m_xWorkingStorageShare
;
95 /** @short global language-independent storage
97 css::uno::Reference
< css::embed::XStorage
> m_xWorkingStorageNoLang
;
99 /** @short holds the folder storage of the user layer alive,
100 where the current configuration set exists.
102 @descr Note: If this preset handler works in document mode
103 this member is meant relative to the document root...
104 not to the user layer root!
106 Further is defined, that m_xWorkingStorageUser
107 is equals to m_xWorkingStorageShare then!
109 css::uno::Reference
< css::embed::XStorage
> m_xWorkingStorageUser
;
111 /** @short knows the relative path from the root. */
112 OUString m_sRelPathShare
;
113 OUString m_sRelPathUser
;
119 /** @short does nothing real.
122 points to a uno service manager, which is used internally
123 to create own needed uno resources.
125 PresetHandler(css::uno::Reference
< css::uno::XComponentContext
> xContext
);
127 /** @short copy ctor */
128 PresetHandler(const PresetHandler
& rCopy
);
130 /** @short closes all open storages ... if user forgot that .-) */
133 /** @short free all currently cache(!) storages. */
134 void forgetCachedStorages();
136 /** @short return access to the internally used and cached root storage.
138 @descr These root storages are the base of all further opened
139 presets and targets. They are provided here only, to support
140 older implementations, which base on them ...
142 getOrCreate...() - What does it mean?
143 Such root storage will be created one times only and
144 cached then internally till the last instance of such PresetHandler
147 @return css::embed::XStorage
148 which represent a root storage.
150 css::uno::Reference
< css::embed::XStorage
> getOrCreateRootStorageShare();
151 css::uno::Reference
< css::embed::XStorage
> getOrCreateRootStorageUser();
153 /** @short provides access to the current working storages.
155 @descr Working storages are the "lowest" storages, where the
156 preset and target files exists.
158 @return css::embed::XStorage
159 which the current working storage.
161 css::uno::Reference
< css::embed::XStorage
> getWorkingStorageUser() const;
163 /** @short check if there is a parent storage well known for
164 the specified child storage and return it.
167 the child storage where a paranet storage should be searched for.
169 @return css::embed::XStorage
170 A valid storage if a paranet exists. NULL otherwise.
172 css::uno::Reference
< css::embed::XStorage
> getParentStorageShare();
173 css::uno::Reference
< css::embed::XStorage
> getParentStorageUser ();
175 /** @short free all internal structures and let this handler
176 work on a new type of configuration sets.
179 differ between global or module dependent configuration.
182 differ between menubar/toolbar/accelerator/... configuration.
185 if sResourceType is set to a module dependent configuration,
186 it address the current application module.
189 if sResourceType is set to E_DOCUMENT, this value points to the
190 root storage inside the document, where we can save our
191 configuration files. Note: that's not the real root of the document...
192 its only a sub storage. But we interpret it as our root storage.
195 in case this configuration supports localized entries,
196 the current locale must be set.
198 Localization will be represented as directory structure
199 of provided presets. Means: you call us with a preset name "default";
200 and we use e.g. "/en-US/default.xml" internally.
202 If no localization exists for this preset set, this class
203 will work in default mode - means "no locale" - automatically.
206 @throw css::uno::RuntimeException(!)
207 if the specified resource couldn't be located.
209 void connectToResource( EConfigType eConfigType
,
210 std::u16string_view sResourceType
,
211 std::u16string_view sModule
,
212 const css::uno::Reference
< css::embed::XStorage
>& xDocumentRoot
,
213 const LanguageTag
& rLanguageTag
= LanguageTag(LANGUAGE_USER_PRIV_NOTRANSLATE
));
215 /** @short try to copy the specified preset from the share
216 layer to the user layer and establish it as the
219 @descr Means: copy share/.../<preset>.xml user/.../<target>.xml
220 Note: The target will be overwritten completely or
221 created as new by this operation!
224 the ALIAS name of an existing preset.
227 the ALIAS name of the target.
229 @throw css::container::NoSuchElementException
230 if the specified preset does not exists.
232 @throw css::io::IOException
235 void copyPresetToTarget(std::u16string_view sPreset
,
236 std::u16string_view sTarget
);
238 /** @short open the specified preset as stream object
241 @descr Note: Because presets resist inside the share
242 layer, they will be opened readonly every time.
245 the ALIAS name of an existing preset.
247 Accesses the global language-independent storage instead of the preset storage
249 @return The opened preset stream ... or NULL if the preset does not exists.
251 css::uno::Reference
< css::io::XStream
> openPreset(std::u16string_view sPreset
);
253 /** @short open the specified target as stream object
256 @descr Note: Targets resist inside the user
257 layer. Normally they are opened in read/write mode.
258 But it will be opened readonly automatically if that isn't possible
259 (may be the file is write protected on the system ...).
262 the ALIAS name of the target.
264 @return The opened target stream ... or NULL if the target does not exists
265 or couldn't be created as new one.
267 css::uno::Reference
< css::io::XStream
> openTarget(
268 std::u16string_view sTarget
, sal_Int32 nMode
);
270 /** @short do anything which is necessary to flush all changes
273 @descr We have to call commit on all cached sub storages on the
274 path from the root storage upside down to the working storage
275 (which are not really used, but required to be holded alive!).
277 void commitUserChanges();
280 void addStorageListener(XMLBasedAcceleratorConfiguration
* pListener
);
281 void removeStorageListener(XMLBasedAcceleratorConfiguration
* pListener
);
287 /** @short open a config path ignoring errors (catching exceptions).
289 @descr We catch only normal exceptions here - no runtime exceptions.
292 the configuration path, which should be opened.
295 the open mode (READ/READWRITE)
298 force using of the share layer instead of the user layer.
300 @return An opened storage in case method was successful - null otherwise.
302 css::uno::Reference
< css::embed::XStorage
> impl_openPathIgnoringErrors(const OUString
& sPath
,
306 /** @short try to find the specified locale inside list of possible ones.
308 @descr The list of possible locale values was e.g. retrieved from the system
309 (configuration, directory listing etcpp). The locale normally represent
310 the current office locale. This method search for a suitable item by using
313 b) search with using fallbacks
315 @param lLocalizedValues
316 list of BCP47 language tags / locale codes
319 [IN ] the current office locale, which should be searched inside lLocalizedValues.
320 [OUT] in case fallbacks was allowed, it contains afterwards the fallback locale.
322 @param bAllowFallbacks
323 enable/disable using of fallbacks
325 @return An iterator, which points directly into lLocalizedValue list.
326 As a negative result the special iterator lLocalizedValues.end() will be returned.
328 ::std::vector
< OUString
>::const_iterator
impl_findMatchingLocalizedValue(const ::std::vector
< OUString
>& lLocalizedValues
,
329 OUString
& rLanguageTag
,
330 bool bAllowFallbacks
);
332 /** @short open a config path ignoring errors (catching exceptions).
334 @descr We catch only normal exceptions here - no runtime exceptions.
335 Further the path itself is tries in different versions (using locale
336 specific attributes).
337 e.g. "path/e-US" => "path/en" => "path/de"
340 the configuration path, which should be opened.
341 It's further used as out parameter too, so we can return the localized
345 the open mode (READ/READWRITE)
348 force using of the share layer instead of the user layer.
351 [IN ] contains the start locale for searching localized sub dirs.
352 [OUT] contains the locale of a found localized sub dir
354 @param bAllowFallback
355 enable/disable fallback handling for locales
357 @return An opened storage in case method was successful - null otherwise.
359 css::uno::Reference
< css::embed::XStorage
> impl_openLocalizedPathIgnoringErrors(OUString
& sPath
,
362 OUString
& rLanguageTag
,
363 bool bAllowFallback
);
365 /** @short returns the names of all sub storages of specified storage.
368 the base storage for this operation.
370 @return [vector< string >]
371 a list of folder names.
373 ::std::vector
< OUString
> impl_getSubFolderNames(const css::uno::Reference
< css::embed::XStorage
>& xFolder
);
376 } // namespace framework
378 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */