256ac118f3fcc0c73226face70422f0ad278f690
[idea/community.git] / java / java-psi-api / src / com / intellij / psi / PsiTypeParameterListOwner.java
1 /*
2  * Copyright 2000-2017 JetBrains s.r.o.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package com.intellij.psi;
17
18 import com.intellij.lang.jvm.JvmTypeParametersOwner;
19 import org.jetbrains.annotations.NotNull;
20 import org.jetbrains.annotations.Nullable;
21
22 /**
23  * Represents a PSI element (class, interface, method or constructor) which can own a type
24  * parameter list.
25  *
26  * @author dsl
27  */
28 public interface PsiTypeParameterListOwner extends PsiMember, JvmTypeParametersOwner {
29   /**
30    * Checks if the element has any type parameters.
31    *
32    * @return true if the element has type parameters, false otherwise
33    */
34   boolean hasTypeParameters();
35
36   /**
37    * Returns the type parameter list for the element.
38    *
39    * @return the type parameter list, or null if the element has no type parameters.
40    */
41   @Nullable
42   PsiTypeParameterList getTypeParameterList();
43
44   /**
45    * Returns the array of type parameters for the element.
46    *
47    * @return the array of type parameters, or an empty array if the element has no type parameters.
48    */
49   @NotNull
50   @Override
51   PsiTypeParameter[] getTypeParameters();
52 }