blob: 78342f73cbef41d91d5108a5d2f7bcb0f7a0d567 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#ifndef __com_sun_star_configuration_UpdateRootElement_idl__
#define __com_sun_star_configuration_UpdateRootElement_idl__
#include <com/sun/star/configuration/AccessRootElement.idl>
#include <com/sun/star/util/XChangesBatch.idl>
module com { module sun { module star { module configuration {
/** provides update control for a hierarchy of configuration items
and information about the hierarchy as a whole as well as its root.
<p>Extends AccessRootElement by adding support for
collecting changes and applying them to a backend store as a single batch.
</p>
<p>An implementation represents the root of a partial hierarchy. [See the
documentation for AccessRootElement]. The hierarchy in turn is
a <em>view</em> onto a fragment of persistent data tree that can be accessed
through several such views, or even several processes, simultaneously.
</p>
<p>Elements of the hierarchy, such as descendants of this root element,
may support modification by providing appropriate
interfaces. Changes done this way initially only affect these objects
themselves and other objects within the same hierarchy, such as other
descendants of this root element.
</p>
<p>The accumulated changes within this hierarchy can be managed using
com::sun::star::util::XChangesBatch. Pending changes
will become persistent and visible from other overlapping hierarchies
only when com::sun::star::util::XChangesBatch::commitChanges()
is called. If the hierarchy is disposed or discarded without committing
changes, the changes will be lost.
</p>
@see com::sun::star::configuration::GroupUpdate
@see com::sun::star::configuration::SetUpdate
*/
published service UpdateRootElement
{
/** provides (read-only) access to information about the root element of
(a fragment of) the hierarchy. It also provides some functionality concerning
the hierarchy (fragment) accessible from that element as a whole.
*/
service AccessRootElement;
/** allows managing changes within the hierarchy.
<p>com::sun::star::util::XChangesBatch::getPendingChanges()
reports all changes within the hierarchy that are done through (direct or
indirect) descendants of this element. The same set of changes is committed
to persistent storage and/or made visible to other objects accessing the same
data set, when
com::sun::star::util::XChangesBatch::commitChanges()
is invoked.
</p>
<p>If the implementation supports
com::sun::star::lang::XLocalizable::setLocale(), changes
will be considered to apply to the locale that is set when
com::sun::star::util::XChangesBatch::commitChanges()
is invoked.
</p>
@see AccessRootElement
@see com::sun::star::util::XChangesNotifier
*/
interface com::sun::star::util::XChangesBatch;
};
}; }; }; };
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|