01: /*
02: * Spoon - http://spoon.gforge.inria.fr/
03: * Copyright (C) 2006 INRIA Futurs <renaud.pawlak@inria.fr>
04: *
05: * This software is governed by the CeCILL-C License under French law and
06: * abiding by the rules of distribution of free software. You can use, modify
07: * and/or redistribute the software under the terms of the CeCILL-C license as
08: * circulated by CEA, CNRS and INRIA at http://www.cecill.info.
09: *
10: * This program is distributed in the hope that it will be useful, but WITHOUT
11: * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12: * FITNESS FOR A PARTICULAR PURPOSE. See the CeCILL-C License for more details.
13: *
14: * The fact that you are presently reading this means that you have had
15: * knowledge of the CeCILL-C license and that you accept its terms.
16: */
17:
18: package spoon.reflect.declaration;
19:
20: import java.util.Set;
21:
22: import spoon.reflect.reference.CtTypeReference;
23:
24: /**
25: * This abstract element defines a super-type for classes and interfaces, which
26: * can declare methods.
27: */
28: public interface CtType<T> extends CtSimpleType<T>, CtGenericElement {
29:
30: /**
31: * Return all the accessible methods for this type (the recursion stops when
32: * the super-type is not in the model).
33: */
34: Set<CtMethod<?>> getAllMethods();
35:
36: /**
37: * Gets a method from its return type, name, and parameter types.
38: *
39: * @return null if does not exit
40: */
41: <R> CtMethod<R> getMethod(CtTypeReference<R> returnType,
42: String name, CtTypeReference<?>... parameterTypes);
43:
44: /**
45: * Gets a method from its name and parameter types.
46: *
47: * @return null if does not exit
48: */
49: CtMethod<?> getMethod(String name,
50: CtTypeReference<?>... parameterTypes);
51:
52: /**
53: * Returns the methods that are directly declared by this class or
54: * interface.
55: */
56: Set<CtMethod<?>> getMethods();
57:
58: /**
59: * Returns the interface types directly implemented by this class or
60: * extended by this interface.
61: */
62: Set<CtTypeReference<?>> getSuperInterfaces();
63:
64: /**
65: * Sets the methods of this type.
66: */
67: void setMethods(Set<CtMethod<?>> methods);
68:
69: /**
70: * Sets the super interfaces of this type.
71: */
72: void setSuperInterfaces(Set<CtTypeReference<?>> interfaces);
73:
74: /**
75: * Tells if this type is a subtype of the given type.
76: */
77: boolean isSubtypeOf(CtTypeReference<?> type);
78:
79: }
|