blob: be97a49e982bdac4d028ab103e4b41ef6a889de9 (
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
|
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef _SVX_ACCESSIBILITY_IACCESSIBLE_PARENT_HXX
#define _SVX_ACCESSIBILITY_IACCESSIBLE_PARENT_HXX
#include <com/sun/star/uno/RuntimeException.hpp>
#include <com/sun/star/drawing/XShape.hpp>
#include <sal/types.h>
namespace accessibility {
class AccessibleShape;
class AccessibleShapeTreeInfo;
/** This interface contains methods missing from the
<type>XAccessibleContext</type> interface that allow the modification of
parent/child relationship.
*/
class IAccessibleParent
{
public:
/** Allow for a virtual destructor.
*/
virtual ~IAccessibleParent (void){};
/** A call to this method requests the implementor to replace one child
with another and send the appropriate notifications. That are two
child events: One notifying the removal of the current child and one
about the existence of the new child. The index of the new child is
implementation dependent, i.e. it is not garanteed that the
replacement has the same index as the current child has.
<p>A default implementation can just use the ShapeTypeHandler::CreateAccessibleObject
to let a factory create the new instance with the parameters given, and then
place the new shape into the own structures.</p>
@param pCurrentChild
This child is about to be replaced.
@param _rxShape
The UNO shape which the old and new child represent
@param _nIndex
The IndexInParent of the old child. Note that the index in
parent of the replacement is not necessarily the same as
that of the current child.
@param _rShapeTreeInfo
The TreeInfo for the old child.
@return
If the replacement has taken place successfully <TRUE/> is
returned. If the replacement can not be carried out or an error
occurs that does not result in an exception then <FALSE/> is
returned.
@raises RuntimeException
in case something went heavily wrong
*/
virtual sal_Bool ReplaceChild (
AccessibleShape* pCurrentChild,
const ::com::sun::star::uno::Reference< ::com::sun::star::drawing::XShape >& _rxShape,
const long _nIndex,
const AccessibleShapeTreeInfo& _rShapeTreeInfo
) throw (::com::sun::star::uno::RuntimeException) = 0;
};
} // end of namespace accessibility
#endif
|