1*b1cdbd2cSJim Jagielski/**************************************************************
2*b1cdbd2cSJim Jagielski *
3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski *
11*b1cdbd2cSJim Jagielski *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski *
13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski * under the License.
19*b1cdbd2cSJim Jagielski *
20*b1cdbd2cSJim Jagielski *************************************************************/
21*b1cdbd2cSJim Jagielski
22*b1cdbd2cSJim Jagielski
23*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_ucb_HierarchyDataReadWriteAccess_idl__
24*b1cdbd2cSJim Jagielski#define __com_sun_star_ucb_HierarchyDataReadWriteAccess_idl__
25*b1cdbd2cSJim Jagielski
26*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_ucb_HierarchyDataReadAccess_idl__
27*b1cdbd2cSJim Jagielski#include <com/sun/star/ucb/HierarchyDataReadAccess.idl>
28*b1cdbd2cSJim Jagielski#endif
29*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_container_XNameContainer_idl__
30*b1cdbd2cSJim Jagielski#include <com/sun/star/container/XNameContainer.idl>
31*b1cdbd2cSJim Jagielski#endif
32*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_lang_XSingleServiceFactory_idl__
33*b1cdbd2cSJim Jagielski#include <com/sun/star/lang/XSingleServiceFactory.idl>
34*b1cdbd2cSJim Jagielski#endif
35*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_util_XChangesBatch_idl__
36*b1cdbd2cSJim Jagielski#include <com/sun/star/util/XChangesBatch.idl>
37*b1cdbd2cSJim Jagielski#endif
38*b1cdbd2cSJim Jagielski
39*b1cdbd2cSJim Jagielski//=============================================================================
40*b1cdbd2cSJim Jagielski
41*b1cdbd2cSJim Jagielskimodule com { module sun { module star { module ucb {
42*b1cdbd2cSJim Jagielski
43*b1cdbd2cSJim Jagielski//=============================================================================
44*b1cdbd2cSJim Jagielski/** provides read and write access to a fragment of the hierarchy data.
45*b1cdbd2cSJim Jagielski*/
46*b1cdbd2cSJim Jagielskipublished service HierarchyDataReadWriteAccess
47*b1cdbd2cSJim Jagielski{
48*b1cdbd2cSJim Jagielski	//-------------------------------------------------------------------------
49*b1cdbd2cSJim Jagielski    /** provides read access to a fragment of the hierarchy data
50*b1cdbd2cSJim Jagielski	 */
51*b1cdbd2cSJim Jagielski    service HierarchyDataReadAccess;
52*b1cdbd2cSJim Jagielski
53*b1cdbd2cSJim Jagielski	//-------------------------------------------------------------------------
54*b1cdbd2cSJim Jagielski    /** allows adding and removing of hierarchy data nodes, replacing of
55*b1cdbd2cSJim Jagielski        the value of hierarchy data node members, as well as obtaining the
56*b1cdbd2cSJim Jagielski        value of hieryrchy data node members.
57*b1cdbd2cSJim Jagielski
58*b1cdbd2cSJim Jagielski        <p>Adding and removing must only be supported if the access object
59*b1cdbd2cSJim Jagielski        points to the "Children" data member of a node or to the root node.
60*b1cdbd2cSJim Jagielski        It will insert a new node or or remove an existing one. If supported
61*b1cdbd2cSJim Jagielski        on data nodes, adding must add new data members to the node, removing
62*b1cdbd2cSJim Jagielski        must remove data members. However, the mandatory data members (Title,
63*b1cdbd2cSJim Jagielski        TargetURL, Children) must never be removable.
64*b1cdbd2cSJim Jagielski
65*b1cdbd2cSJim Jagielski        <p>Replacing and getting values must be supported be every data node.
66*b1cdbd2cSJim Jagielski	 */
67*b1cdbd2cSJim Jagielski    interface com::sun::star::container::XNameContainer;
68*b1cdbd2cSJim Jagielski
69*b1cdbd2cSJim Jagielski	//-------------------------------------------------------------------------
70*b1cdbd2cSJim Jagielski	/** gives access to all contents provided by this provider.
71*b1cdbd2cSJim Jagielski
72*b1cdbd2cSJim Jagielski        <p><member scope="com::sun::star::lang">XSingleServiceFactory::createInstance</member>
73*b1cdbd2cSJim Jagielski        will create a new empty hierarchy data node. After it was created
74*b1cdbd2cSJim Jagielski        it's data members can be filled. Last, the node can be inserted as child
75*b1cdbd2cSJim Jagielski        of another node using
76*b1cdbd2cSJim Jagielski        <member scope="com::sun::star::container">XNameContainer::insertByName</member>.
77*b1cdbd2cSJim Jagielski
78*b1cdbd2cSJim Jagielski        <p>There are no special arguments that must be supported by
79*b1cdbd2cSJim Jagielski        <member scope="com::sun::star::lang">XSingleServiceFactory::createInstanceWithArguments</member>
80*b1cdbd2cSJim Jagielski	 */
81*b1cdbd2cSJim Jagielski    interface com::sun::star::lang::XSingleServiceFactory;
82*b1cdbd2cSJim Jagielski
83*b1cdbd2cSJim Jagielski	//-------------------------------------------------------------------------
84*b1cdbd2cSJim Jagielski    /** allows managing changes within the hierarchy.
85*b1cdbd2cSJim Jagielski
86*b1cdbd2cSJim Jagielski        <p><member scope="com::sun::star::util">XChangesBatch::getPendingChanges</member>
87*b1cdbd2cSJim Jagielski        reports all changes within the hierarchy that are done through (direct
88*b1cdbd2cSJim Jagielski        or indirect) descendants of this element. The same set of changes is
89*b1cdbd2cSJim Jagielski        committed to persistent storage and/or made visible to other objects
90*b1cdbd2cSJim Jagielski        accessing the same data set, when
91*b1cdbd2cSJim Jagielski        <member scope="com::sun::star::util">XChangesBatch::commitChanges</member>
92*b1cdbd2cSJim Jagielski        is invoked.
93*b1cdbd2cSJim Jagielski     */
94*b1cdbd2cSJim Jagielski    interface com::sun::star::util::XChangesBatch;
95*b1cdbd2cSJim Jagielski};
96*b1cdbd2cSJim Jagielski
97*b1cdbd2cSJim Jagielski//=============================================================================
98*b1cdbd2cSJim Jagielski
99*b1cdbd2cSJim Jagielski}; }; }; };
100*b1cdbd2cSJim Jagielski
101*b1cdbd2cSJim Jagielski#endif
102