1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski package com.sun.star.uno;
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski import java.lang.reflect.Method;
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski /**
31*b1cdbd2cSJim Jagielski  * The <code>IMethodDescription</code> allows to examine a method
32*b1cdbd2cSJim Jagielski  * in detail. It gives a view to java methods from a UNO point.
33*b1cdbd2cSJim Jagielski  *
34*b1cdbd2cSJim Jagielski  * @deprecated This interface does not cover all the features supported by the
35*b1cdbd2cSJim Jagielski  * corresponding (unpublished) implementation.  But no client code should need
36*b1cdbd2cSJim Jagielski  * to access this functionality, anyway.
37*b1cdbd2cSJim Jagielski  */
38*b1cdbd2cSJim Jagielski public interface IMethodDescription extends IMemberDescription {
39*b1cdbd2cSJim Jagielski 	/**
40*b1cdbd2cSJim Jagielski 	 * Indicates if this method is <code>oneWay</code>,
41*b1cdbd2cSJim Jagielski 	 * respectivly if this method may become executed asynchronously.
42*b1cdbd2cSJim Jagielski 	 * <p>
43*b1cdbd2cSJim Jagielski 	 * @return  true means may execute asynchronously .
44*b1cdbd2cSJim Jagielski 	 */
isOneway()45*b1cdbd2cSJim Jagielski 	boolean isOneway();
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski 	/**
48*b1cdbd2cSJim Jagielski 	 * Indicates if this method is const.
49*b1cdbd2cSJim Jagielski 	 * <p>
50*b1cdbd2cSJim Jagielski 	 * @return true means it is const.
51*b1cdbd2cSJim Jagielski 	 */
isConst()52*b1cdbd2cSJim Jagielski 	boolean isConst();
53*b1cdbd2cSJim Jagielski 
54*b1cdbd2cSJim Jagielski 	/**
55*b1cdbd2cSJim Jagielski 	 * Gives any array of <code>ITypeDescription</code> of
56*b1cdbd2cSJim Jagielski 	 * the [in] parameters.
57*b1cdbd2cSJim Jagielski 	 * <p>
58*b1cdbd2cSJim Jagielski 	 * @return  the in parameters
59*b1cdbd2cSJim Jagielski 	 */
getInSignature()60*b1cdbd2cSJim Jagielski 	ITypeDescription[] getInSignature();
61*b1cdbd2cSJim Jagielski 
62*b1cdbd2cSJim Jagielski 	/**
63*b1cdbd2cSJim Jagielski 	 * Gives any array of <code>ITypeDescription</code> of
64*b1cdbd2cSJim Jagielski 	 * the [out] parameters.
65*b1cdbd2cSJim Jagielski 	 * <p>
66*b1cdbd2cSJim Jagielski 	 * @return  the out parameters
67*b1cdbd2cSJim Jagielski 	 */
getOutSignature()68*b1cdbd2cSJim Jagielski 	ITypeDescription[] getOutSignature();
69*b1cdbd2cSJim Jagielski 
70*b1cdbd2cSJim Jagielski 	/**
71*b1cdbd2cSJim Jagielski 	 * Gives the <code>ITypeDescription</code> of
72*b1cdbd2cSJim Jagielski 	 * the return type.
73*b1cdbd2cSJim Jagielski 	 * <p>
74*b1cdbd2cSJim Jagielski 	 * @return  the return type <code>ITypeDescription</code>
75*b1cdbd2cSJim Jagielski 	 */
getReturnSignature()76*b1cdbd2cSJim Jagielski 	ITypeDescription getReturnSignature();
77*b1cdbd2cSJim Jagielski 
78*b1cdbd2cSJim Jagielski 	/**
79*b1cdbd2cSJim Jagielski 	 * Gives native java method of this method.
80*b1cdbd2cSJim Jagielski 	 * <p>
81*b1cdbd2cSJim Jagielski 	 * @return  the java methodd
82*b1cdbd2cSJim Jagielski 	 */
getMethod()83*b1cdbd2cSJim Jagielski 	Method getMethod();
84*b1cdbd2cSJim Jagielski }
85