|
37 | 37 | import javax.lang.model.element.Modifier;
|
38 | 38 | import javax.lang.model.element.PackageElement;
|
39 | 39 | import javax.lang.model.element.TypeElement;
|
| 40 | +import javax.lang.model.element.TypeParameterElement; |
40 | 41 | import javax.lang.model.element.VariableElement;
|
41 | 42 | import javax.lang.model.type.TypeKind;
|
42 | 43 | import javax.lang.model.type.TypeMirror;
|
@@ -129,6 +130,33 @@ public static TypeElement asType(Element element) {
|
129 | 130 | return element.accept(TypeElementVisitor.INSTANCE, null);
|
130 | 131 | }
|
131 | 132 |
|
| 133 | + /** |
| 134 | + * Returns the given {@link Element} instance as {@link TypeParameterElement}. |
| 135 | + * |
| 136 | + * <p>This method is functionally equivalent to an {@code instanceof} check and a cast, but should |
| 137 | + * always be used over that idiom as instructed in the documentation for {@link Element}. |
| 138 | + * |
| 139 | + * @throws NullPointerException if {@code element} is {@code null} |
| 140 | + * @throws IllegalArgumentException if {@code element} isn't a {@link TypeParameterElement}. |
| 141 | + */ |
| 142 | + public static TypeParameterElement asTypeParameter(Element element) { |
| 143 | + return element.accept(TypeParameterElementVisitor.INSTANCE, null); |
| 144 | + } |
| 145 | + |
| 146 | + private static final class TypeParameterElementVisitor |
| 147 | + extends CastingElementVisitor<TypeParameterElement> { |
| 148 | + private static final TypeParameterElementVisitor INSTANCE = new TypeParameterElementVisitor(); |
| 149 | + |
| 150 | + TypeParameterElementVisitor() { |
| 151 | + super("type parameter element"); |
| 152 | + } |
| 153 | + |
| 154 | + @Override |
| 155 | + public TypeParameterElement visitTypeParameter(TypeParameterElement e, Void ignore) { |
| 156 | + return e; |
| 157 | + } |
| 158 | + } |
| 159 | + |
132 | 160 | private static final class VariableElementVisitor extends CastingElementVisitor<VariableElement> {
|
133 | 161 | private static final VariableElementVisitor INSTANCE = new VariableElementVisitor();
|
134 | 162 |
|
|
0 commit comments