Can this tree carry attributes (i.e. symbols, types or positions)? Typically the answer is yes, except for the EmptyTree
null object and two special singletons: noSelfType
and pendingSuperCall
.
The direct child trees of this tree. EmptyTrees are always omitted. Lists are flattened.
Apply pf
to each subtree on which the function is defined and collect the results.
Make a copy of this tree, keeping all attributes, except that all positions are focused (so nothing in this tree will be found when searching by position).
Tests whether two trees are structurally equal. Note that ==
on trees is reference equality.
Is there exists a part of this tree which satisfies predicate p
?
Find all subtrees matching predicate p
. Same as withFilter
Returns optionally first tree (in a preorder traversal) which satisfies predicate p
, or None if none exists.
Do all parts of this tree satisfy predicate p
?
Apply f
to each subtree
Does this tree represent a definition? (of a method, of a class, etc)
Is this tree one of the empty trees?
Empty trees are: the EmptyTree
null object and TypeTree
instances that don't carry a type.
canHaveAttrs
The canonical way to test if a Tree represents a term.
The canonical way to test if a Tree represents a type.
Modifiers of the declared member.
The underlying name. For example, the List
part of Ident(TermName("List"))
.
Is this tree not an empty tree?
isEmpty
Provides an alternate if tree is empty
The alternate tree
If this tree is non empty, this tree, otherwise alt
.
Position of the tree.
The body of the definition. The EmptyTree
is the body is empty (e.g. for abstract members).
Symbol of the tree.
For most trees symbol is null
. In SymTree
s, it is overridden and implemented with a var, initialized to NoSymbol
.
Trees which are not SymTree
s but which carry symbols do so by overriding def symbol
to forward it elsewhere. Examples:
Super(qual, _)
has qual
's symbol,
Apply(fun, args)
has fun
's symbol,
TypeApply(fun, args)
has fun
's symbol,
AppliedTypeTree(tpt, args)
has tpt
's symbol,
TypeTree(tpe)
has tpe
's typeSymbol
, if tpe != null
. Type of the tree.
Upon creation most trees have their tpe
set to null
. Types are typically assigned to trees during typechecking. Some node factory methods set tpe
immediately after creation.
When the typechecker encounters a tree with a non-null tpe, it will assume it to be correct and not check it again. This means one has to be careful not to erase the tpe
field of subtrees.
The type ascribed to the definition. An empty TypeTree
if the type hasn't been specified explicitly and is supposed to be inferred.
Find all subtrees matching predicate p
. Same as filter
Obtains string representation of a tree
© 2002-2019 EPFL, with contributions from Lightbend.
Licensed under the Apache License, Version 2.0.
https://www.scala-lang.org/api/2.13.0/scala-reflect/scala/reflect/api/Trees$ValDefApi.html
The API that all val defs support