aboutsummaryrefslogtreecommitdiff
path: root/src/dotty/tools/dotc/transform/NormalizeFlags.scala
blob: bdec800c70eb47beeacf043606b760bbca1b889b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package dotty.tools.dotc
package transform

import core._
import DenotTransformers.SymTransformer
import Phases.Phase
import Contexts.Context
import SymDenotations.SymDenotation
import TreeTransforms.MiniPhaseTransform
import Flags._, Symbols._

/** 1. Widens all private[this] and protected[this] qualifiers to just private/protected 
 *  2. Sets PureInterface flag for traits that only have pure interface members and that
 *     do not have initialization code. A pure interface member is either an abstract
 *     or alias type definition or a deferred val or def.
 */
class NormalizeFlags extends MiniPhaseTransform with SymTransformer { thisTransformer =>
  override def phaseName = "normalizeFlags"

  def transformSym(ref: SymDenotation)(implicit ctx: Context) = {
    var newFlags = ref.flags &~ Local
    if (ref.is(NoInitsTrait) && ref.info.decls.forall(isPureInterfaceMember)) 
      newFlags |= PureInterface
    if (newFlags != ref.flags) ref.copySymDenotation(initFlags = newFlags)
    else ref
  }
  
  private def isPureInterfaceMember(sym: Symbol)(implicit ctx: Context) = 
    if (sym.isTerm) sym.is(Deferred) else !sym.isClass
}