Class TypeDeclaration
TypeDeclaration: ClassDeclaration InterfaceDeclaration ClassDeclaration: [ Javadoc ] { ExtendedModifier } class Identifier [ < TypeParameter { , TypeParameter } > ] [ extends Type ] [ implements Type { , Type } ] [ permits Type { , Type } ] { { ClassBodyDeclaration | ; } } InterfaceDeclaration: [ Javadoc ] { ExtendedModifier } interface Identifier [ < TypeParameter { , TypeParameter } > ] [ extends Type { , Type } ] [ permits Type { , Type } ] { { InterfaceBodyDeclaration | ; } }
When a Javadoc comment is present, the source range begins with the first character of the "/**" comment delimiter. When there is no Javadoc comment, the source range begins with the first character of the first modifier or annotation (if any), or the first character of the "class" or "interface" keyword (if no modifiers or annotations). The source range extends through the last character of the "}" token following the body declarations.
- Since:
- 2.0
- Restriction:
- This class is not intended to be instantiated by clients.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final ChildListPropertyDescriptor
The "bodyDeclarations" structural property of this node type (element type:BodyDeclaration
) (added in JLS3 API).static final SimplePropertyDescriptor
The "interface" structural property of this node type (type:Boolean
).static final ChildPropertyDescriptor
The "javadoc" structural property of this node type (child type:Javadoc
).static final SimplePropertyDescriptor
Deprecated.static final ChildListPropertyDescriptor
The "modifiers" structural property of this node type (element type:IExtendedModifier
) (added in JLS3 API).static final ChildPropertyDescriptor
The "name" structural property of this node type (child type:SimpleName
).static final ChildListPropertyDescriptor
The "permitsTypes" structural property of this node type (element type:Type
) (added in JLS15 API).static final ChildListPropertyDescriptor
The "superInterfaceTypes" structural property of this node type (element type:Type
) (added in JLS3 API).static final ChildListPropertyDescriptor
Deprecated.In the JLS3 API, this property is replaced bySUPER_INTERFACE_TYPES_PROPERTY
.static final ChildPropertyDescriptor
Deprecated.In the JLS3 API, this property is replaced bySUPERCLASS_TYPE_PROPERTY
.static final ChildPropertyDescriptor
The "superclassType" structural property of this node type (child type:Type
) (added in JLS3 API).static final ChildListPropertyDescriptor
The "typeParameters" structural property of this node type (element type:TypeParameter
) (added in JLS3 API).Fields inherited from class org.eclipse.jdt.core.dom.ASTNode
ANNOTATION_TYPE_DECLARATION, ANNOTATION_TYPE_MEMBER_DECLARATION, ANONYMOUS_CLASS_DECLARATION, ARRAY_ACCESS, ARRAY_CREATION, ARRAY_INITIALIZER, ARRAY_TYPE, ASSERT_STATEMENT, ASSIGNMENT, BLOCK, BLOCK_COMMENT, BOOLEAN_LITERAL, BREAK_STATEMENT, CASE_DEFAULT_EXPRESSION, CAST_EXPRESSION, CATCH_CLAUSE, CHARACTER_LITERAL, CLASS_INSTANCE_CREATION, COMPILATION_UNIT, CONDITIONAL_EXPRESSION, CONSTRUCTOR_INVOCATION, CONTINUE_STATEMENT, CREATION_REFERENCE, DIMENSION, DO_STATEMENT, EitherOr_MultiPattern, EMPTY_STATEMENT, ENHANCED_FOR_STATEMENT, ENUM_CONSTANT_DECLARATION, ENUM_DECLARATION, EXPORTS_DIRECTIVE, EXPRESSION_METHOD_REFERENCE, EXPRESSION_STATEMENT, FIELD_ACCESS, FIELD_DECLARATION, FOR_STATEMENT, GUARDED_PATTERN, IF_STATEMENT, IMPORT_DECLARATION, INFIX_EXPRESSION, INITIALIZER, INSTANCEOF_EXPRESSION, INTERSECTION_TYPE, JAVADOC, JAVADOC_REGION, JAVADOC_TEXT_ELEMENT, LABELED_STATEMENT, LAMBDA_EXPRESSION, LINE_COMMENT, MALFORMED, MARKER_ANNOTATION, MEMBER_REF, MEMBER_VALUE_PAIR, METHOD_DECLARATION, METHOD_INVOCATION, METHOD_REF, METHOD_REF_PARAMETER, MODIFIER, MODULE_DECLARATION, MODULE_MODIFIER, MODULE_QUALIFIED_NAME, NAME_QUALIFIED_TYPE, NORMAL_ANNOTATION, NULL_LITERAL, NULL_PATTERN, NUMBER_LITERAL, OPENS_DIRECTIVE, ORIGINAL, PACKAGE_DECLARATION, PARAMETERIZED_TYPE, PARENTHESIZED_EXPRESSION, PATTERN_INSTANCEOF_EXPRESSION, POSTFIX_EXPRESSION, PREFIX_EXPRESSION, PRIMITIVE_TYPE, PROTECT, PROVIDES_DIRECTIVE, QUALIFIED_NAME, QUALIFIED_TYPE, RECORD_DECLARATION, RECORD_PATTERN, RECOVERED, REQUIRES_DIRECTIVE, RETURN_STATEMENT, SIMPLE_NAME, SIMPLE_TYPE, SINGLE_MEMBER_ANNOTATION, SINGLE_VARIABLE_DECLARATION, STRING_FRAGMENT, STRING_LITERAL, STRING_TEMPLATE_COMPONENT, STRING_TEMPLATE_EXPRESSION, SUPER_CONSTRUCTOR_INVOCATION, SUPER_FIELD_ACCESS, SUPER_METHOD_INVOCATION, SUPER_METHOD_REFERENCE, SWITCH_CASE, SWITCH_EXPRESSION, SWITCH_STATEMENT, SYNCHRONIZED_STATEMENT, TAG_ELEMENT, TAG_PROPERTY, TEXT_BLOCK, TEXT_ELEMENT, THIS_EXPRESSION, THROW_STATEMENT, TRY_STATEMENT, TYPE_DECLARATION, TYPE_DECLARATION_STATEMENT, TYPE_LITERAL, TYPE_METHOD_REFERENCE, TYPE_PARAMETER, TYPE_PATTERN, UNION_TYPE, UNNAMED_CLASS, USES_DIRECTIVE, VARIABLE_DECLARATION_EXPRESSION, VARIABLE_DECLARATION_FRAGMENT, VARIABLE_DECLARATION_STATEMENT, WHILE_STATEMENT, WILDCARD_TYPE, YIELD_STATEMENT
-
Method Summary
Modifier and TypeMethodDescriptionReturns the ordered list of field declarations of this type declaration.Returns the ordered list of method declarations of this type declaration.int
A character index into the original restricted identifier source string, or-1
if no restricted identifier source position information is available for this node;-1
by default.Deprecated.In the JLS3 API, this method is replaced bygetSuperclassType()
, which returns aType
instead of aName
.Returns the superclass declared in this type declaration, ornull
if there is none (added in JLS3 API).getTypes()
Returns the ordered list of member type declarations of this type declaration.boolean
Returns whether this type declaration declares a class or an interface.Returns the live ordered list of permits of this type declaration (added in JLS17 API).static List
propertyDescriptors
(int apiLevel) Returns a list of structural property descriptors for this node type.void
setInterface
(boolean isInterface) Sets whether this type declaration declares a class or an interface.void
setRestrictedIdentifierStartPosition
(int restrictedIdentifierStartPosition) A character index into the original restricted identifier source string, or-1
if no restricted identifier source position information is available for this node;-1
by default.void
setSuperclass
(Name superclassName) Deprecated.In the JLS3 API, this method is replaced bysetSuperclassType(Type)
, which expects aType
instead of aName
.void
setSuperclassType
(Type superclassType) Sets or clears the superclass declared in this type declaration (added in JLS3 API).Deprecated.In the JLS3 API, this method is replaced bysuperInterfaceTypes()
.Returns the live ordered list of superinterfaces of this type declaration (added in JLS3 API).Returns the live ordered list of type parameters of this type declaration (added in JLS3 API).Methods inherited from class org.eclipse.jdt.core.dom.AbstractTypeDeclaration
bodyDeclarations, getBodyDeclarationsProperty, getName, getNameProperty, isLocalTypeDeclaration, isMemberTypeDeclaration, isPackageMemberTypeDeclaration, resolveBinding, setName
Methods inherited from class org.eclipse.jdt.core.dom.BodyDeclaration
getJavadoc, getJavadocProperty, getModifiers, getModifiersProperty, modifiers, setJavadoc, setModifiers
Methods inherited from class org.eclipse.jdt.core.dom.ASTNode
accept, copySubtree, copySubtrees, delete, equals, getAST, getFlags, getLength, getLocationInParent, getNodeType, getParent, getProperty, getRoot, getStartPosition, getStructuralProperty, hashCode, nodeClassForType, properties, setFlags, setProperty, setSourceRange, setStructuralProperty, structuralPropertiesForType, subtreeBytes, subtreeMatch, toString
-
Field Details
-
JAVADOC_PROPERTY
The "javadoc" structural property of this node type (child type:Javadoc
).- Since:
- 3.0
-
MODIFIERS_PROPERTY
Deprecated.In the JLS3 API, this property is replaced byMODIFIERS2_PROPERTY
.The "modifiers" structural property of this node type (type:Integer
) (JLS2 API only).- Since:
- 3.0
-
MODIFIERS2_PROPERTY
The "modifiers" structural property of this node type (element type:IExtendedModifier
) (added in JLS3 API).- Since:
- 3.1
-
INTERFACE_PROPERTY
The "interface" structural property of this node type (type:Boolean
).- Since:
- 3.0
-
NAME_PROPERTY
The "name" structural property of this node type (child type:SimpleName
).- Since:
- 3.0
-
SUPERCLASS_PROPERTY
Deprecated.In the JLS3 API, this property is replaced bySUPERCLASS_TYPE_PROPERTY
.The "superclass" structural property of this node type (child type:Name
) (JLS2 API only).- Since:
- 3.0
-
SUPER_INTERFACES_PROPERTY
Deprecated.In the JLS3 API, this property is replaced bySUPER_INTERFACE_TYPES_PROPERTY
.The "superInterfaces" structural property of this node type (element type:Name
) (JLS2 API only).- Since:
- 3.0
-
SUPERCLASS_TYPE_PROPERTY
The "superclassType" structural property of this node type (child type:Type
) (added in JLS3 API).- Since:
- 3.1
-
SUPER_INTERFACE_TYPES_PROPERTY
The "superInterfaceTypes" structural property of this node type (element type:Type
) (added in JLS3 API).- Since:
- 3.1
-
TYPE_PARAMETERS_PROPERTY
The "typeParameters" structural property of this node type (element type:TypeParameter
) (added in JLS3 API).- Since:
- 3.1
-
BODY_DECLARATIONS_PROPERTY
The "bodyDeclarations" structural property of this node type (element type:BodyDeclaration
) (added in JLS3 API).- Since:
- 3.0
-
PERMITS_TYPES_PROPERTY
The "permitsTypes" structural property of this node type (element type:Type
) (added in JLS15 API).- Since:
- 3.24
-
-
Method Details
-
propertyDescriptors
Returns a list of structural property descriptors for this node type. Clients must not modify the result.- Parameters:
apiLevel
- the API level; one of theAST.JLS*
constants- Returns:
- a list of property descriptors (element type:
StructuralPropertyDescriptor
) - Since:
- 3.0
-
isInterface
public boolean isInterface()Returns whether this type declaration declares a class or an interface.- Returns:
true
if this is an interface declaration, andfalse
if this is a class declaration
-
setInterface
public void setInterface(boolean isInterface) Sets whether this type declaration declares a class or an interface.- Parameters:
isInterface
-true
if this is an interface declaration, andfalse
if this is a class declaration
-
typeParameters
Returns the live ordered list of type parameters of this type declaration (added in JLS3 API). This list is non-empty for parameterized types.- Returns:
- the live list of type parameters
(element type:
TypeParameter
) - Throws:
UnsupportedOperationException
- if this operation is used in a JLS2 AST- Since:
- 3.1
-
getSuperclass
Deprecated.In the JLS3 API, this method is replaced bygetSuperclassType()
, which returns aType
instead of aName
.Returns the name of the superclass declared in this type declaration, ornull
if there is none (JLS2 API only).Note that this child is not relevant for interface declarations (although it does still figure in subtree equality comparisons).
- Returns:
- the superclass name node, or
null
if there is none - Throws:
UnsupportedOperationException
- if this operation is used in an AST later than JLS2
-
getSuperclassType
Returns the superclass declared in this type declaration, ornull
if there is none (added in JLS3 API).Note that this child is not relevant for interface declarations (although it does still figure in subtree equality comparisons).
- Returns:
- the superclass type node, or
null
if there is none - Throws:
UnsupportedOperationException
- if this operation is used in a JLS2 AST- Since:
- 3.1
-
setSuperclass
Deprecated.In the JLS3 API, this method is replaced bysetSuperclassType(Type)
, which expects aType
instead of aName
.Sets or clears the name of the superclass declared in this type declaration (JLS2 API only).Note that this child is not relevant for interface declarations (although it does still figure in subtree equality comparisons).
- Parameters:
superclassName
- the superclass name node, ornull
if there is none- Throws:
IllegalArgumentException
- if:- the node belongs to a different AST
- the node already has a parent
UnsupportedOperationException
- if this operation is used in an AST later than JLS2
-
setSuperclassType
Sets or clears the superclass declared in this type declaration (added in JLS3 API).Note that this child is not relevant for interface declarations (although it does still figure in subtree equality comparisons).
- Parameters:
superclassType
- the superclass type node, ornull
if there is none- Throws:
IllegalArgumentException
- if:- the node belongs to a different AST
- the node already has a parent
UnsupportedOperationException
- if this operation is used in a JLS2 AST- Since:
- 3.1
-
superInterfaces
Deprecated.In the JLS3 API, this method is replaced bysuperInterfaceTypes()
.Returns the live ordered list of names of superinterfaces of this type declaration (JLS2 API only). For a class declaration, these are the names of the interfaces that this class implements; for an interface declaration, these are the names of the interfaces that this interface extends.- Returns:
- the live list of interface names
(element type:
Name
) - Throws:
UnsupportedOperationException
- if this operation is used in an AST later than JLS2
-
superInterfaceTypes
Returns the live ordered list of superinterfaces of this type declaration (added in JLS3 API). For a class declaration, these are the interfaces that this class implements; for an interface declaration, these are the interfaces that this interface extends.- Returns:
- the live list of interface types
(element type:
Type
) - Throws:
UnsupportedOperationException
- if this operation is used in a JLS2 AST- Since:
- 3.1
-
permittedTypes
Returns the live ordered list of permits of this type declaration (added in JLS17 API). For a type declaration, these are the permitted types which can implement/extend this sealed type.- Returns:
- the live list of types
(element type:
Type
) - Throws:
UnsupportedOperationException
- if this operation is not used with Java 17 and above- Since:
- 3.27
-
getFields
Returns the ordered list of field declarations of this type declaration. For a class declaration, these are the field declarations; for an interface declaration, these are the constant declarations.This convenience method returns this node's body declarations with non-fields filtered out. Unlike
bodyDeclarations
, this method does not return a live result.- Returns:
- the (possibly empty) list of field declarations
-
getMethods
Returns the ordered list of method declarations of this type declaration.This convenience method returns this node's body declarations with non-methods filtered out. Unlike
bodyDeclarations
, this method does not return a live result.- Returns:
- the (possibly empty) list of method (and constructor) declarations
-
getTypes
Returns the ordered list of member type declarations of this type declaration.This convenience method returns this node's body declarations with non-types filtered out. Unlike
bodyDeclarations
, this method does not return a live result.- Returns:
- the (possibly empty) list of member type declarations
-
setRestrictedIdentifierStartPosition
public void setRestrictedIdentifierStartPosition(int restrictedIdentifierStartPosition) A character index into the original restricted identifier source string, or-1
if no restricted identifier source position information is available for this node;-1
by default.- Since:
- 3.28
-
getRestrictedIdentifierStartPosition
public int getRestrictedIdentifierStartPosition()A character index into the original restricted identifier source string, or-1
if no restricted identifier source position information is available for this node;-1
by default.- Since:
- 3.28
-
MODIFIERS2_PROPERTY
.