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.List;
21:
22: import spoon.reflect.reference.CtTypeReference;
23:
24: /**
25: * This element defines a type parameter (aka generics).
26: */
27: public interface CtTypeParameter extends CtElement {
28:
29: /**
30: * Returns the bounds of this type parameter. These are the types given by
31: * the <i>extends</i> clause. If there is no explicit <i>extends</i>
32: * clause, then <tt>java.lang.Object</tt> is considered to be the sole
33: * bound.
34: */
35: List<CtTypeReference<?>> getBounds();
36:
37: /**
38: * Returns the name of this type parameter.
39: */
40: String getName();
41:
42: /**
43: * Sets the bounds of this type parameter.
44: */
45: void setBounds(List<CtTypeReference<?>> bounds);
46:
47: /**
48: * Sets the name of this type parameter.
49: */
50: void setName(String name);
51:
52: }
|