Package org.eclipse.jdt.core.dom
Class ClassInstanceCreation
java.lang.Object
org.eclipse.jdt.core.dom.ASTNode
org.eclipse.jdt.core.dom.Expression
org.eclipse.jdt.core.dom.ClassInstanceCreation
Class instance creation expression AST node type.
ClassInstanceCreation: [ Expression . ] new [ < Type { , Type } > ] Type ( [ Expression { , Expression } ] ) [ AnonymousClassDeclaration ]
Not all node arrangements will represent legal Java constructs. In particular,
it is nonsense if the type is a primitive type or an array type (primitive
types cannot be instantiated, and array creations must be represented with
ArrayCreation
nodes). The normal use is when the type is a
simple, qualified, or parameterized type.
QualifiedType
discusses typical representations of qualified type references.
- Since:
- 2.0
- Restriction:
- This class is not intended to be instantiated by clients.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final ChildPropertyDescriptor
The "anonymousClassDeclaration" structural property of this node type (child type:AnonymousClassDeclaration
).static final ChildListPropertyDescriptor
The "arguments" structural property of this node type (element type:Expression
).static final ChildPropertyDescriptor
The "expression" structural property of this node type (child type:Expression
).static final ChildPropertyDescriptor
Deprecated.static final ChildListPropertyDescriptor
The "typeArguments" structural property of this node type (element type:Type
) (added in JLS3 API).static final ChildPropertyDescriptor
The "type" structural property of this node type (child type:Type
) (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_LITERAL, 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 live ordered list of argument expressions in this class instance creation expression.Returns the anonymous class declaration introduced by this class instance creation expression, if it has one.Returns the expression of this class instance creation expression, ornull
if there is none.getName()
Deprecated.getType()
Returns the type instantiated in this class instance creation expression (added in JLS3 API).boolean
Returnstrue
if the resolved class type has been inferred from the assignment context (JLS4 15.12.2.8),false
otherwise.static List
propertyDescriptors
(int apiLevel) Returns a list of structural property descriptors for this node type.Resolves and returns the binding for the constructor invoked by this expression.void
Sets whether this class instance creation expression declares an anonymous class (that is, has class body declarations).void
setExpression
(Expression expression) Sets or clears the expression of this class instance creation expression.void
Deprecated.void
Sets the type instantiated in this class instance creation expression (added in JLS3 API).Returns the live ordered list of type arguments of this class instance creation (added in JLS3 API).Methods inherited from class org.eclipse.jdt.core.dom.Expression
resolveBoxing, resolveConstantExpressionValue, resolveTypeBinding, resolveUnboxing
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
-
TYPE_ARGUMENTS_PROPERTY
The "typeArguments" structural property of this node type (element type:Type
) (added in JLS3 API).- Since:
- 3.1
-
EXPRESSION_PROPERTY
The "expression" structural property of this node type (child type:Expression
).- Since:
- 3.0
-
NAME_PROPERTY
Deprecated.In the JLS3 API, this property is replaced byTYPE_PROPERTY
.The "name" structural property of this node type (child type:Name
) (JLS2 API only).- Since:
- 3.0
-
TYPE_PROPERTY
The "type" structural property of this node type (child type:Type
) (added in JLS3 API).- Since:
- 3.1
-
ARGUMENTS_PROPERTY
The "arguments" structural property of this node type (element type:Expression
).- Since:
- 3.0
-
ANONYMOUS_CLASS_DECLARATION_PROPERTY
The "anonymousClassDeclaration" structural property of this node type (child type:AnonymousClassDeclaration
).- Since:
- 3.0
-
-
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
-
getExpression
Returns the expression of this class instance creation expression, ornull
if there is none.- Returns:
- the expression node, or
null
if there is none
-
setExpression
Sets or clears the expression of this class instance creation expression.- Parameters:
expression
- the expression node, ornull
if there is none- Throws:
IllegalArgumentException
- if:- the node belongs to a different AST
- the node already has a parent
- a cycle in would be created
-
typeArguments
Returns the live ordered list of type arguments of this class instance creation (added in JLS3 API).- Returns:
- the live list of type arguments
(element type:
Type
) - Throws:
UnsupportedOperationException
- if this operation is used in a JLS2 AST- Since:
- 3.1
-
getName
Deprecated.Returns the name of the type instantiated in this class instance creation expression (JLS2 API only).- Returns:
- the type name node
- Throws:
UnsupportedOperationException
- if this operation is used in an AST later than JLS2
-
setName
Deprecated.Sets the name of the type instantiated in this class instance creation expression (JLS2 API only).- Parameters:
name
- the new type name- 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
-
getType
Returns the type instantiated in this class instance creation expression (added in JLS3 API).- Returns:
- the type node
- Throws:
UnsupportedOperationException
- if this operation is used in a JLS2 AST- Since:
- 3.1
-
setType
Sets the type instantiated in this class instance creation expression (added in JLS3 API).- Parameters:
type
- the new type- 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
-
arguments
Returns the live ordered list of argument expressions in this class instance creation expression.- Returns:
- the live list of argument expressions (possibly empty)
(element type:
Expression
)
-
getAnonymousClassDeclaration
Returns the anonymous class declaration introduced by this class instance creation expression, if it has one.- Returns:
- the anonymous class declaration, or
null
if none
-
setAnonymousClassDeclaration
Sets whether this class instance creation expression declares an anonymous class (that is, has class body declarations).- Parameters:
decl
- the anonymous class declaration, ornull
if none
-
resolveConstructorBinding
Resolves and returns the binding for the constructor invoked by this expression. For anonymous classes, the binding is that of the anonymous constructor.Note that bindings are generally unavailable unless requested when the AST is being built.
- Returns:
- the constructor binding, or
null
if the binding cannot be resolved
-
isResolvedTypeInferredFromExpectedType
public boolean isResolvedTypeInferredFromExpectedType()Returnstrue
if the resolved class type has been inferred from the assignment context (JLS4 15.12.2.8),false
otherwise.This information is available only when bindings are requested when the AST is being built.
- Returns:
true
if the resolved class type has been inferred from the assignment context (JLS3 15.12.2.8),false
otherwise- Since:
- 3.7.1
-
TYPE_PROPERTY
.