MiniPhase

dotty.tools.dotc.transform.MegaPhase.MiniPhase
abstract class MiniPhase extends Phase

The base class of tree transforms. For each kind of tree K, there are two methods which can be overridden:

prepareForK: return a new Context which gets passed to the node and its children transformK // transform node of type K

There are also prepare/transform hooks for

  • Stats: to prepare/transform a statement sequence in a block, template, or package def,
  • Unit : to prepare/transform a whole compilation unit
  • Other: to prepape/transform a tree that does not have a specific prepare/transform method pair.

Attributes

Graph
Supertypes
class Phase
class Object
trait Matchable
class Any
Known subtypes
trait PluginPhase
class ArrayApply
class BetaReduce
class CapturedVars
class CheckStatic
class CheckUnused
class PostInlining
class PostTyper
class Constructors
class CookComments
class DropBreaks
class ElimByName
class ElimOpaque
class ElimRepeated
class EtaReduce
class ExpandSAMs
class ExplicitSelf
class Flatten
class Getters
class InlineVals
class LambdaLift
class LazyVals
class LetOverApply
class LiftTry
class Memoize
class Mixin
class MoveStatics
class PureStats
class ResolveSuper
class SelectStatic
class SeqLiterals
class TailRec
class RefChecks
Show all

Members list

Value members

Concrete methods

def prepareForApply(tree: Apply)(using Context): Context
def prepareForAssign(tree: Assign)(using Context): Context
def prepareForBind(tree: Bind)(using Context): Context
def prepareForBlock(tree: Block)(using Context): Context
def prepareForDefDef(tree: DefDef)(using Context): Context
def prepareForIdent(tree: Ident)(using Context): Context
def prepareForIf(tree: If)(using Context): Context
def prepareForMatch(tree: Match)(using Context): Context
def prepareForNew(tree: New)(using Context): Context
def prepareForOther(tree: Tree)(using Context): Context
def prepareForQuote(tree: Quote)(using Context): Context
def prepareForReturn(tree: Return)(using Context): Context
def prepareForSelect(tree: Select)(using Context): Context
def prepareForSplice(tree: Splice)(using Context): Context
def prepareForStats(trees: List[Tree])(using Context): Context
def prepareForSuper(tree: Super)(using Context): Context
def prepareForThis(tree: This)(using Context): Context
def prepareForTry(tree: Try)(using Context): Context
def prepareForTyped(tree: Typed)(using Context): Context
def prepareForUnit(tree: Tree)(using Context): Context
def prepareForValDef(tree: ValDef)(using Context): Context
final override def relaxedTyping: Boolean

If set, allow missing or superfluous arguments in applications and type applications.

If set, allow missing or superfluous arguments in applications and type applications.

Attributes

Definition Classes

If set, use relaxed typing for all phases in group

If set, use relaxed typing for all phases in group

Attributes

override def run(using Context): Unit

Attributes

Definition Classes

List of names of phases that should have finished their processing of all compilation units before this phase starts

List of names of phases that should have finished their processing of all compilation units before this phase starts

Attributes

protected def singletonGroup: MegaPhase
def transformAllDeep(tree: Tree)(using Context): Tree

Transform tree using all transforms of current group (including this one)

Transform tree using all transforms of current group (including this one)

Attributes

def transformApply(tree: Apply)(using Context): Tree
def transformAssign(tree: Assign)(using Context): Tree
def transformBind(tree: Bind)(using Context): Tree
def transformBlock(tree: Block)(using Context): Tree
def transformCaseDef(tree: CaseDef)(using Context): Tree
def transformClosure(tree: Closure)(using Context): Tree
def transformDefDef(tree: DefDef)(using Context): Tree
def transformFollowing(tree: Tree)(using Context): Tree

Transform single node using all transforms following the current one in this group

Transform single node using all transforms following the current one in this group

Attributes

Transform tree using all transforms following the current one in this group

Transform tree using all transforms following the current one in this group

Attributes

def transformIdent(tree: Ident)(using Context): Tree
def transformIf(tree: If)(using Context): Tree
def transformInlined(tree: Inlined)(using Context): Tree
def transformLabeled(tree: Labeled)(using Context): Tree
def transformLiteral(tree: Literal)(using Context): Tree
def transformMatch(tree: Match)(using Context): Tree
def transformNew(tree: New)(using Context): Tree
def transformOther(tree: Tree)(using Context): Tree
def transformQuote(tree: Quote)(using Context): Tree
def transformReturn(tree: Return)(using Context): Tree
def transformSelect(tree: Select)(using Context): Tree
def transformSplice(tree: Splice)(using Context): Tree
def transformStats(trees: List[Tree])(using Context): List[Tree]
def transformSuper(tree: Super)(using Context): Tree
def transformTemplate(tree: Template)(using Context): Tree
def transformThis(tree: This)(using Context): Tree
def transformTry(tree: Try)(using Context): Tree
def transformTypeDef(tree: TypeDef)(using Context): Tree
def transformTypeTree(tree: TypeTree)(using Context): Tree
def transformTyped(tree: Typed)(using Context): Tree
def transformUnApply(tree: UnApply)(using Context): Tree
def transformUnit(tree: Tree)(using Context): Tree
def transformValDef(tree: ValDef)(using Context): Tree
def transformWhileDo(tree: WhileDo)(using Context): Tree

Inherited methods

final def <=(that: Phase): Boolean

Attributes

Inherited from:
Phase

If set, implicit search is enabled

If set, implicit search is enabled

Attributes

Inherited from:
Phase

Can this transform change the base types of a type?

Can this transform change the base types of a type?

Attributes

Inherited from:
Phase

Can this transform create or delete non-private members?

Can this transform create or delete non-private members?

Attributes

Inherited from:
Phase

Can this transform change the parents of a class?

Can this transform change the parents of a class?

Attributes

Inherited from:
Phase
def checkPostCondition(tree: Tree)(using Context): Unit

Check what the phase achieves, to be called at any point after it is finished.

Check what the phase achieves, to be called at any point after it is finished.

Attributes

Inherited from:
Phase

Attributes

Inherited from:
Phase
def end: PhaseId

Attributes

Inherited from:
Phase
final def erasedTypes: Boolean

Attributes

Inherited from:
Phase

Attributes

Inherited from:
Phase
final def flatClasses: Boolean

Attributes

Inherited from:
Phase
final def hasNext: Boolean

Attributes

Inherited from:
Phase
def id: Int

The sequence position of this phase in the given context where 0 is reserved for NoPhase and the first real phase is at position 1. -1 if the phase is not installed in the context.

The sequence position of this phase in the given context where 0 is reserved for NoPhase and the first real phase is at position 1. -1 if the phase is not installed in the context.

Attributes

Inherited from:
Phase

Attributes

Inherited from:
Phase

Output should be checkable by TreeChecker

Output should be checkable by TreeChecker

Attributes

Inherited from:
Phase
def isEnabled(using Context): Boolean

Attributes

Inherited from:
Phase
def isRunnable(using Context): Boolean

Attributes

Inherited from:
Phase

Is this phase the standard typerphase? True for TyperPhase, but not for other first phases (such as FromTasty or Parser). The predicate is tested in some places that perform checks and corrections. It's different from ctx.isAfterTyper (and cheaper to test).

Is this phase the standard typerphase? True for TyperPhase, but not for other first phases (such as FromTasty or Parser). The predicate is tested in some places that perform checks and corrections. It's different from ctx.isAfterTyper (and cheaper to test).

Attributes

Inherited from:
Phase
final def iterator: Iterator[Phase]

Attributes

Inherited from:
Phase
final def lambdaLifted: Boolean

Attributes

Inherited from:
Phase
final def monitor(doing: String)(body: => Unit)(using Context): Unit

Attributes

Inherited from:
Phase
final def next: Phase

Attributes

Inherited from:
Phase

Attributes

Inherited from:
Phase
def period: Period

Attributes

Inherited from:
Phase

A name given to the Phase that can be used to debug the compiler. For instance, it is possible to print trees after a given phase using:

A name given to the Phase that can be used to debug the compiler. For instance, it is possible to print trees after a given phase using:

$ ./bin/scalac -Xprint:<phaseNameHere> sourceFile.scala

Attributes

Inherited from:
Phase
final def prev: Phase

Attributes

Inherited from:
Phase
final def prevMega(using Context): Phase

Attributes

Inherited from:
Phase
final def refChecked: Boolean

Attributes

Inherited from:
Phase

Attributes

Inherited from:
Phase

List of names of phases that should precede this phase

List of names of phases that should precede this phase

Attributes

Inherited from:
Phase

Attributes

Inherited from:
Phase
final def sameMembersStartId: Int

Attributes

Inherited from:
Phase
final def sameParentsStartId: Int

Attributes

Inherited from:
Phase
def show(tree: Tree)(using Context): String

Convert a compilation unit's tree to a string; can be overridden

Convert a compilation unit's tree to a string; can be overridden

Attributes

Inherited from:
Phase
def start: Int

Attributes

Inherited from:
Phase
override def toString: String

Returns a string representation of the object.

Returns a string representation of the object.

The default representation is platform dependent.

Attributes

Returns

a string representation of the object.

Definition Classes
Phase -> Any
Inherited from:
Phase

Concrete fields