This phase performs the following transformations:
-
(done in
traitDefs
andtransformSym
) For every concrete trait getterdef x(): T = expr
make it non-private, and add the definition of its trait setter:
<mods> def TraitName$_setter_$x(v: T): Unit
-
(done in
traitDefs
) Make every concrete trait setterdef x_=(y: T) = ()
deferred by mapping it to
<mods> def x_=(y: T)
-
(done in
transformSym
) For every module class constructor in traits, remove its Private flag (but do not expand its name), since it will have to be instantiated in the classes that mix in the trait. -
For a non-trait class C:
For every trait M directly implemented by the class (see SymUtils.mixin), in reverse linearization order, add the following definitions to C:
4.1 (done in `traitInits`) For every parameter accessor `<mods> def x(): T` in M, in order of textual occurrence, add <mods> def x() = e where `e` is the constructor argument in C that corresponds to `x`. Issue an error if no such argument exists. 4.2 (done in `traitInits`) For every concrete trait getter `<mods> def x(): T` in M which is not a parameter accessor, in order of textual occurrence, produce the following: 4.2.1 If `x` is also a member of `C`, and is a lazy val, <mods> lazy val x: T = super[M].x 4.2.2 If `x` is also a member of `C`, and is a module, <mods> lazy module val x: T = new T$(this) 4.2.3 If `x` is also a member of `C`, and is something else: <mods> def x(): T = _ 4.2.5 If `x` is not a member of `C`, nothing gets added. 4.3 (done in `superCallOpt`) The call: super[M].$init$() 4.4 (done in `setters`) For every concrete setter `<mods> def x_=(y: T)` in M: <mods> def x_=(y: T) = () 4.5 (done in `mixinForwarders`) For every method `<mods> def f[Ts](ps1)...(psN): U` imn M` that needs to be disambiguated: <mods> def f[Ts](ps1)...(psN): U = super[M].f[Ts](ps1)...(psN) A method in M needs to be disambiguated if it is concrete, not overridden in C, and if it overrides another concrete method.
-
(done in
transformTemplate
andtransformSym
) Drop all parameters from trait constructors, and rename them tonme.TRAIT_CONSTRUCTOR
. -
(done in
transformSym
) Drop ParamAccessor flag from all parameter accessors in traits.
Conceptually, this is the second half of the previous mixin phase. It needs to run after erasure because it copies references to possibly private inner classes and objects into enclosing classes where they are not visible. This can only be done if all references are symbolic.
- Companion:
- object
Value members
Concrete methods
Can this transform create or delete non-private members?
Can this transform create or delete non-private members?
- Definition Classes
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
- Definition Classes
If set, use relaxed typing for all phases in group
If set, use relaxed typing for all phases in group
- Definition Classes
List of names of phases that should precede this phase
List of names of phases that should precede this phase
- Definition Classes
Inherited methods
Can this transform change the base types of a type?
Can this transform change the base types of a type?
- Inherited from:
- Phase
Can this transform change the parents of a class?
Can this transform change the parents of a class?
- Inherited from:
- Phase
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.
- Inherited from:
- Phase
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.
- Inherited from:
- Phase
Output should be checkable by TreeChecker
Output should be checkable by TreeChecker
- 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).
- Inherited from:
- Phase
The last phase during which the transformed denotations are valid
The last phase during which the transformed denotations are valid
- Inherited from:
- DenotTransformer
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
- Inherited from:
- MiniPhase
Transform tree using all transforms of current group (including this one)
Transform tree using all transforms of current group (including this one)
- Inherited from:
- MiniPhase
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
- Inherited from:
- MiniPhase
Transform tree using all transforms following the current one in this group
Transform tree using all transforms following the current one in this group
- Inherited from:
- MiniPhase
The validity period of the transformed denotations in the given context
The validity period of the transformed denotations in the given context
- Inherited from:
- DenotTransformer