1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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 .
19 #ifndef __com_sun_star_script_InvocationInfo_idl__
20 #define __com_sun_star_script_InvocationInfo_idl__
22 #include
<com
/sun
/star
/script
/MemberType.idl
>
24 #include
<com
/sun
/star
/reflection
/ParamMode.idl
>
27 module com
{ module sun
{ module star
{ module script
{
31 This struct is used to specify information about object members
32 (methods or properties) accessed via XInvocation, such as names,
36 published
struct InvocationInfo
39 /** Name of the method or property.
43 /** Kind of the member (method or property).
45 MemberType eMemberType
;
47 /** Only for property members:
48 This field may contain zero or more constants of the
49 com::sun::star::beans::PropertyAttribute
50 constants group. It is not guaranteed that all necessary
51 constants are set to describe the property completely,
52 but a flag will only be set, if the corresponding charac-
53 teristic really exists. Example: If the READONLY flag
54 is set, the property is readonly. If it isn't set, the
55 property nevertheless can be readonly.
57 For methods this field is irrelevant and is set to 0.
59 short PropertyAttribute
;
61 /** Type of the member, for methods the return type
65 /** Types method parameters, for properties this sequence is empty
67 sequence
< type
> aParamTypes
;
69 /** Mode of method parameters (IN, OUT, INOUT),
70 for properties this sequence is empty.
72 sequence
< com
::sun
::star
::reflection
::ParamMode
> aParamModes
;
80 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */