1/**************************************************************
2 *
3 * Licensed to the Apache Software Foundation (ASF) under one
4 * or more contributor license agreements.  See the NOTICE file
5 * distributed with this work for additional information
6 * regarding copyright ownership.  The ASF licenses this file
7 * to you under the Apache License, Version 2.0 (the
8 * "License"); you may not use this file except in compliance
9 * with the License.  You may obtain a copy of the License at
10 *
11 *   http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing,
14 * software distributed under the License is distributed on an
15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16 * KIND, either express or implied.  See the License for the
17 * specific language governing permissions and limitations
18 * under the License.
19 *
20 *************************************************************/
21
22
23
24#ifndef __com_sun_star_reflection_XInterfaceAttributeTypeDescription2_idl__
25#define __com_sun_star_reflection_XInterfaceAttributeTypeDescription2_idl__
26
27#include "com/sun/star/reflection/XInterfaceAttributeTypeDescription.idl"
28
29module com {  module sun {  module star {  module reflection {
30
31interface XCompoundTypeDescription;
32
33/**
34   Reflects an interface attribute, supporting extended attributes that are
35   bound or raise exceptions.
36
37   <p>This type supersedes <type>XInterfaceAttributeTypeDescription</type>,
38   which does not support extended attributes.</p>
39
40   @since OpenOffice 2.0
41 */
42interface XInterfaceAttributeTypeDescription2:
43    XInterfaceAttributeTypeDescription
44{
45    /**
46       Returns whether this object reflects a bound attribute.
47
48       @return <TRUE/> iff this object reflects a bound attribute
49     */
50    boolean isBound();
51
52    /**
53       Returns the exceptions that can be raised by the attribute's getter.
54
55       @return the reflections of all the exceptions that are listed in the
56       <code>raises</code> specification of the attribute's getter (if any), in
57       no particular order; all elements of the returned sequence will be
58       reflections of exception types
59     */
60    sequence<XCompoundTypeDescription> getGetExceptions();
61
62    /**
63       Returns the exceptions that can be raised by the attribute's setter.
64
65       @return the reflections of all the exceptions that are listed in the
66       <code>raises</code> specification of the attribute's setter (if any), in
67       no particular order; all elements of the returned sequence will be
68       reflections of exception types
69     */
70    sequence<XCompoundTypeDescription> getSetExceptions();
71};
72
73}; }; }; };
74
75#endif
76