1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2000, 2010 Oracle and/or its affiliates.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * This file is part of OpenOffice.org.
11 * OpenOffice.org is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU Lesser General Public License version 3
13 * only, as published by the Free Software Foundation.
15 * OpenOffice.org is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License version 3 for more details
19 * (a copy is included in the LICENSE file that accompanied this code).
21 * You should have received a copy of the GNU Lesser General Public License
22 * version 3 along with OpenOffice.org. If not, see
23 * <http://www.openoffice.org/license.html>
24 * for a copy of the LGPLv3 License.
26 ************************************************************************/
27 #ifndef __com_sun_star_reflection_XIdlArray_idl__
28 #define __com_sun_star_reflection_XIdlArray_idl__
30 #ifndef __com_sun_star_uno_XInterface_idl__
31 #include
<com
/sun
/star
/uno
/XInterface.idl
>
34 #ifndef __com_sun_star_lang_IllegalArgumentException_idl__
35 #include
<com
/sun
/star
/lang
/IllegalArgumentException.idl
>
38 #ifndef __com_sun_star_lang_ArrayIndexOutOfBoundsException_idl__
39 #include
<com
/sun
/star
/lang
/ArrayIndexOutOfBoundsException.idl
>
43 //=============================================================================
45 module com
{ module sun
{ module star
{ module reflection
{
47 //=============================================================================
49 /** Reflects an IDL sequence and provides dynamic access to instances of
51 This interface supports widening conversion when getting or setting elements.
54 Although the name of this interface denotes arrays,
55 sequences are meant. Don't be obfuscated, arrays are not supported by UNO!
57 published
interface XIdlArray
: com
::sun
::star
::uno
::XInterface
59 /** Rellocates the length of the sequence instance.
64 new length of sequence
69 raises
( com
::sun
::star
::lang
::IllegalArgumentException
);
71 /** Returns the length of the given sequence.
78 long getLen
( [in] any array
)
79 raises
( com
::sun
::star
::lang
::IllegalArgumentException
);
81 /** Returns element at given index.
90 @throws IllegalArgumentException
91 if the specified object is not a sequence or if the specified object is null
93 @throws ArrayIndexOutOfBoundsException
94 if the specified index argument is negative, or if it is greater than or equal to the
95 length of the specified sequence.
100 raises
( com
::sun
::star
::lang
::IllegalArgumentException
,
101 com
::sun
::star
::lang
::ArrayIndexOutOfBoundsException
);
103 /** Sets a new value at given index.
112 @throws IllegalArgumentException
113 if the specified object is not a sequence or if the specified object is null
115 @throws ArrayIndexOutOfBoundsException
116 if the specified index argument is negative, or if it is greater than or equal to the
117 length of the specified sequence.
123 raises
( com
::sun
::star
::lang
::IllegalArgumentException
,
124 com
::sun
::star
::lang
::ArrayIndexOutOfBoundsException
);
127 //=============================================================================
131 /*=============================================================================
133 =============================================================================*/