cid#1640468 Dereference after null check
[LibreOffice.git] / offapi / com / sun / star / ucb / HierarchyDataReadWriteAccess.idl
blob0b49f23ec85a75122a461b0b2e0fe900de004879
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 .
21 module com { module sun { module star { module ucb {
23 /** provides read and write access to a fragment of the hierarchy data.
25 published service HierarchyDataReadWriteAccess
27 /** provides read access to a fragment of the hierarchy data
29 service HierarchyDataReadAccess;
31 /** allows adding and removing of hierarchy data nodes, replacing of
32 the value of hierarchy data node members, as well as obtaining the
33 value of hierarchy data node members.
35 <p>Adding and removing must only be supported if the access object
36 points to the "Children" data member of a node or to the root node.
37 It will insert a new node or remove an existing one. If supported
38 on data nodes, adding must add new data members to the node, removing
39 must remove data members. However, the mandatory data members (Title,
40 TargetURL, Children) must never be removable.
42 <p>Replacing and getting values must be supported be every data node.
44 interface com::sun::star::container::XNameContainer;
46 /** gives access to all contents provided by this provider.
48 <p>com::sun::star::lang::XSingleServiceFactory::createInstance()
49 will create a new empty hierarchy data node. After it was created
50 it's data members can be filled. Last, the node can be inserted as child
51 of another node using
52 com::sun::star::container::XNameContainer::insertByName().
54 <p>There are no special arguments that must be supported by
55 com::sun::star::lang::XSingleServiceFactory::createInstanceWithArguments()
57 interface com::sun::star::lang::XSingleServiceFactory;
59 /** allows managing changes within the hierarchy.
61 <p>com::sun::star::util::XChangesBatch::getPendingChanges()
62 reports all changes within the hierarchy that are done through (direct
63 or indirect) descendants of this element. The same set of changes is
64 committed to persistent storage and/or made visible to other objects
65 accessing the same data set, when
66 com::sun::star::util::XChangesBatch::commitChanges()
67 is invoked.
69 interface com::sun::star::util::XChangesBatch;
73 }; }; }; };
75 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */