scala.tools.nsc.transform

Erasure

abstract class Erasure extends AddInterfaces with Erasure with Analyzer with TypingTransformers with TreeDSL

Source
Erasure.scala
Linear Supertypes
Known Subclasses
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. Erasure
  2. TypingTransformers
  3. Analyzer
  4. StdAttachments
  5. ContextErrors
  6. TypeDiagnostics
  7. NamesDefaults
  8. Macros
  9. Traces
  10. Unapplies
  11. SyntheticMethods
  12. EtaExpansion
  13. Variances
  14. Implicits
  15. Infer
  16. Typers
  17. PatMatVirtualiser
  18. TreeDSL
  19. Taggings
  20. Adaptations
  21. Modes
  22. Namers
  23. MethodSynthesis
  24. Contexts
  25. Erasure
  26. AddInterfaces
  27. InfoTransform
  28. Transform
  29. SubComponent
  30. AnyRef
  31. Any
Implicitly
  1. by any2stringfmt
  2. by any2stringadd
  3. by any2ArrowAssoc
  4. by any2Ensuring
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Erasure()

Type Members

  1. trait AbsTypeError extends Throwable

  2. trait Adaptation extends AnyRef

  3. case class AmbiguousTypeError(underlyingTree: Tree, errPos: Position, errMsg: String, kind: ErrorKind) extends Throwable with AbsTypeError with Product with Serializable

  4. class ClassMethodSynthesis extends AnyRef

  5. trait CodegenCore extends MatchMonadInterface

  6. trait CommonSubconditionElimination extends TreeMakerApproximation

  7. class ComputeBridges extends AnyRef

  8. class Context extends AnyRef

  9. trait DeadCodeElimination extends TreeMakers

  10. class Eraser extends Typer

    The modifier typer which retypes with erased types.

  11. abstract class ErasureMap extends TypeMap

  12. class ErasureTransformer extends Transformer

    The erasure transformer

  13. class ImplicitInfo extends AnyRef

    A class that records an available implicit

  14. class ImplicitSearch extends Typer with ImplicitsContextErrors

    A class that sets up an implicit search.

  15. trait ImplicitsContextErrors extends AnyRef

  16. class ImportInfo extends AnyRef

  17. case class ImportType(expr: Tree) extends Type with Product with Serializable

  18. class Inferencer extends InferencerContextErrors

    The context-dependent inferencer part

  19. trait InferencerContextErrors extends AnyRef

  20. class JavaErasureMap extends ErasureMap

  21. trait LockingTypeCompleter extends TypeCompleter

  22. case class MacroAttachment(delayed: Boolean, typerContext: Context, macroContext: Option[Context]) extends Product with Serializable

  23. trait MatchMonadInterface extends AnyRef

    Interface with user-defined match monad? if there's a match in scope, we use this as the match strategy, assuming it conforms to MatchStrategy as defined below:

  24. trait MatchOptimizations extends CommonSubconditionElimination with DeadCodeElimination with SwitchEmission with OptimizedCodegen

  25. trait MatchTranslation extends MatchMonadInterface

  26. trait MethodSynth extends AnyRef

    There are two key methods in here.

  27. case class NamedApplyInfo(qual: Option[Tree], targs: List[Tree], vargss: List[List[Tree]], blockTyper: Typer) extends Product with Serializable

  28. abstract class Namer extends MethodSynth with NamerContextErrors

  29. trait NamerContextErrors extends AnyRef

  30. class NoInstance extends Throwable with ControlThrowable

  31. case class NormalTypeError(underlyingTree: Tree, errMsg: String, kind: ErrorKind) extends Throwable with AbsTypeError with Product with Serializable

  32. trait OptimizedCodegen extends CodegenCore with TypedSubstitution with OptimizedMatchMonadInterface

  33. trait OptimizedMatchMonadInterface extends MatchMonadInterface

  34. class OptimizingMatchTranslator extends MatchTranslation with TreeMakers with MatchOptimizations

  35. class Phase extends Phase

    The phase defined by this transform

  36. class PolyTypeCompleter extends TypeCompleter with LockingTypeCompleter

    A class representing a lazy type with known type parameters.

  37. case class PosAndMsgTypeError(errPos: Position, errMsg: String, kind: ErrorKind) extends Throwable with AbsTypeError with Product with Serializable

  38. trait PureCodegen extends CodegenCore with PureMatchMonadInterface

  39. trait PureMatchMonadInterface extends MatchMonadInterface

  40. class PureMatchTranslator extends MatchTranslation with TreeMakers with PureCodegen

  41. class ScalaErasureMap extends ErasureMap

    Scala's more precise erasure than java's is problematic as follows:

  42. class SearchResult extends AnyRef

    The result of an implicit search

  43. sealed abstract class SilentResult[+T] extends AnyRef

  44. case class SilentResultValue[+T](value: T) extends SilentResult[T] with Product with Serializable

  45. case class SilentTypeError(err: AbsTypeError) extends SilentResult[Nothing] with Product with Serializable

  46. abstract class StdPhase extends GlobalPhase

    A standard phase template

  47. trait SwitchEmission extends TreeMakers with OptimizedMatchMonadInterface

  48. case class SymbolTypeError(underlyingSym: Symbol, errMsg: String, kind: ErrorKind) extends Throwable with AbsTypeError with Product with Serializable

  49. trait Tagging extends AnyRef

  50. trait TreeMakerApproximation extends TreeMakers

  51. trait TreeMakers extends TypedSubstitution

  52. abstract class TypeCompleter extends LazyType

  53. case class TypeDiag(tp: Type, sym: Symbol) extends Ordered[TypeDiag] with Product with Serializable

  54. case class TypeErrorWithUnderlyingTree(tree: Tree, ex: TypeError, kind: ErrorKind) extends Throwable with AbsTypeError with Product with Serializable

  55. case class TypeErrorWrapper(ex: TypeError, kind: ErrorKind) extends Throwable with AbsTypeError with Product with Serializable

  56. trait TypedSubstitution extends MatchMonadInterface

  57. abstract class Typer extends TyperDiagnostics with Adaptation with Tagging with TyperContextErrors

  58. trait TyperContextErrors extends AnyRef

  59. trait TyperDiagnostics extends AnyRef

  60. abstract class TypingTransformer extends Transformer

  61. class UnknownSig extends Exception

Abstract Value Members

  1. abstract val global: Global

    Definition Classes
    TypingTransformers
  2. abstract val runsAfter: List[String]

    List of phase names, this phase should run after

    List of phase names, this phase should run after

    Definition Classes
    SubComponent
  3. abstract val runsRightAfter: Option[String]

    Phase name this phase will attach itself to, not allowing any phase to come between it and the phase name declared

    Phase name this phase will attach itself to, not allowing any phase to come between it and the phase name declared

    Definition Classes
    SubComponent

Concrete Value Members

  1. final def !=(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  2. final def !=(arg0: Any): Boolean

    Definition Classes
    Any
  3. final def ##(): Int

    Definition Classes
    AnyRef → Any
  4. def +(other: String): String

    Implicit information
    This member is added by an implicit conversion from Erasure to StringAdd performed by method any2stringadd in scala.Predef.
    Definition Classes
    StringAdd
  5. def ->[B](y: B): (Erasure, B)

    Implicit information
    This member is added by an implicit conversion from Erasure to ArrowAssoc[Erasure] performed by method any2ArrowAssoc in scala.Predef.
    Definition Classes
    ArrowAssoc
    Annotations
    @inline()
  6. final def ==(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  7. final def ==(arg0: Any): Boolean

    Definition Classes
    Any
  8. final val ALTmode: Int(8192)

    ALTmode is set when we are under a pattern alternative.

    ALTmode is set when we are under a pattern alternative.

    Definition Classes
    Modes
  9. final val BYVALmode: Int(32768)

    BYVALmode is set when we are typing an expression that occurs in a by-value position.

    BYVALmode is set when we are typing an expression that occurs in a by-value position. An expression e1 is in by-value position within expression e2 iff it will be reduced to a value at that position during the evaluation of e2. Examples are by-value function arguments or the conditional of an if-then-else clause. This mode has been added to support continuations.

    Definition Classes
    Modes
  10. object Boxed extends AnyRef

    An extractor object for boxed expressions (maybe subsumed by posterasure?)

  11. object CODE extends AnyRef

  12. final val EXPRmode: Int(1)

    Definition Classes
    Modes
  13. object ErrorKinds extends Enumeration

  14. object ErrorUtils extends AnyRef

  15. final val FUNmode: Int(16)

    FUNmode is orthogonal to above.

    FUNmode is orthogonal to above. When set we are looking for a method or constructor.

    Definition Classes
    Modes
  16. object Function1 extends AnyRef

    An extractor for unary function types arg => res

  17. object GenericArray extends AnyRef

    An extractor object for generic arrays

  18. final val HKmode: Int(16384)

    HKmode is set when we are typing a higher-kinded type.

    HKmode is set when we are typing a higher-kinded type. adapt should then check kind-arity based on the prototypical type's kind arity. Type arguments should not be inferred.

    Definition Classes
    Modes
  19. object HasMember extends AnyRef

    An extractor for types of the form ? { name: ? }

  20. object HasMethodMatching extends AnyRef

    An extractor for types of the form ? { name: (? >: argtpe <: Any*)restp }

  21. object ImplicitNotFoundMsg extends AnyRef

  22. final val LHSmode: Int(1024)

    LHSmode is set for the left-hand side of an assignment.

    LHSmode is set for the left-hand side of an assignment.

    Definition Classes
    Modes
  23. object MatchTranslator extends AnyRef

  24. final val NOmode: Int(0)

    NOmode, EXPRmode and PATTERNmode are mutually exclusive.

    NOmode, EXPRmode and PATTERNmode are mutually exclusive.

    Definition Classes
    Modes
  25. object NamesDefaultsErrorsGen extends AnyRef

  26. object NoContext extends Context

  27. val NoImplicitInfo: ImplicitInfo

    A sentinel indicating no implicit was found

    A sentinel indicating no implicit was found

    Definition Classes
    Implicits
  28. final val PATTERNmode: Int(2)

    Definition Classes
    Modes
  29. final val POLYmode: Int(32)

    POLYmode is orthogonal to above.

    POLYmode is orthogonal to above. When set expression types can be polymorphic.

    Definition Classes
    Modes
  30. final val QUALmode: Int(64)

    QUALmode is orthogonal to above.

    QUALmode is orthogonal to above. When set expressions may be packages and Java statics modules.

    Definition Classes
    Modes
  31. final val SCCmode: Int(8)

    SCCmode is orthogonal to above.

    SCCmode is orthogonal to above. When set we are in the this or super constructor call of a constructor.

    Definition Classes
    Modes
  32. final val SNDTRYmode: Int(512)

    SNDTRYmode indicates that an application is typed for the 2nd time.

    SNDTRYmode indicates that an application is typed for the 2nd time. In that case functions may no longer be coerced with implicit views.

    Definition Classes
    Modes
  33. final val STARmode: Int(4096)

    STARmode is set when star patterns are allowed.

    STARmode is set when star patterns are allowed. (This was formerly called REGPATmode.)

    Definition Classes
    Modes
  34. final val SUPERCONSTRmode: Int(256)

    SUPERCONSTRmode is set for the super in a superclass constructor call super.

    SUPERCONSTRmode is set for the super in a superclass constructor call super.<init>.

    Definition Classes
    Modes
  35. val SYNTH_CASE: Int

    Definition Classes
    PatMatVirtualiser
  36. lazy val SearchFailure: SearchResult

    Definition Classes
    Implicits
  37. final val TAPPmode: Int(128)

    TAPPmode is set for the function/type constructor part of a type application.

    TAPPmode is set for the function/type constructor part of a type application. When set we do not decompose PolyTypes.

    Definition Classes
    Modes
  38. final val TYPEPATmode: Int(65536)

    TYPEPATmode is set when we are typing a type in a pattern.

    TYPEPATmode is set when we are typing a type in a pattern.

    Definition Classes
    Modes
  39. final val TYPEmode: Int(4)

    TYPEmode needs a comment.

    TYPEmode needs a comment. <-- XXX.

    Definition Classes
    Modes
  40. object UnTyper extends Traverser

  41. object Unboxed extends AnyRef

    An extractor object for unboxed expressions (maybe subsumed by posterasure?)

  42. def abstractVarMessage(sym: Symbol): String

    An explanatory note to be added to error messages when there's a problem with abstract var defs

    An explanatory note to be added to error messages when there's a problem with abstract var defs

    Definition Classes
    TypeDiagnostics
  43. def actualArgs(pos: Position, actuals: List[Tree], nformals: Int): List[Tree]

    Definition Classes
    Infer
  44. def actualTypes(actuals: List[Type], nformals: Int): List[Type]

    Definition Classes
    Infer
  45. def addDefaults(givenArgs: List[Tree], qual: Option[Tree], targs: List[Tree], previousArgss: List[List[Tree]], params: List[Symbol], pos: Position, context: Context): (List[Tree], List[Symbol])

    Extend the argument list givenArgs with default arguments.

    Extend the argument list givenArgs with default arguments. Defaults are added as named arguments calling the corresponding default getter.

    Example: given def foo(x: Int = 2, y: String = "def") foo(y = "lt") the argument list (y = "lt") is transformed to (y = "lt", x = foo$default$1())

    Definition Classes
    NamesDefaults
  46. def addSyntheticMethods(templ: Template, clazz0: Symbol, context: Context): Template

    Add the synthetic methods to case classes.

    Add the synthetic methods to case classes.

    Definition Classes
    SyntheticMethods
  47. final def afterOwnPhase[T](op: ⇒ T): T

    Definition Classes
    SubComponent
    Annotations
    @inline()
  48. def allViewsFrom(tp: Type, context: Context, tpars: List[Symbol]): List[(SearchResult, List[TypeConstraint])]

    Find all views from type tp (in which tpars are free)

    Find all views from type tp (in which tpars are free)

    Note that the trees in the search results in the returned list share the same type variables. Ignore their constr field! The list of type constraints returned along with each tree specifies the constraints that must be met by the corresponding type parameter in tpars (for the returned implicit view to be valid).

    Definition Classes
    Implicits
  49. def alternatives(tree: Tree): List[Type]

    Definition Classes
    TypeDiagnostics
  50. def alternativesString(tree: Tree): String

    Definition Classes
    TypeDiagnostics
  51. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  52. final def beforeOwnPhase[T](op: ⇒ T): T

    Definition Classes
    SubComponent
    Annotations
    @inline()
  53. def caseClassCopyMeth(cdef: ClassDef): Option[DefDef]

    Definition Classes
    Unapplies
  54. def caseModuleApplyMeth(cdef: ClassDef): DefDef

    The apply method corresponding to a case class

    The apply method corresponding to a case class

    Definition Classes
    Unapplies
  55. def caseModuleDef(cdef: ClassDef): ModuleDef

    The module corresponding to a case class; overrides toString to show the module's name

    The module corresponding to a case class; overrides toString to show the module's name

    Definition Classes
    Unapplies
  56. def caseModuleUnapplyMeth(cdef: ClassDef): DefDef

    The unapply method corresponding to a case class

    The unapply method corresponding to a case class

    Definition Classes
    Unapplies
  57. def changesBaseClasses: Boolean

    Attributes
    protected
    Definition Classes
    InfoTransform
  58. def clone(): AnyRef

    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws()
  59. def companionModuleDef(cdef: ClassDef, parents: List[Tree] = Nil, body: List[Tree] = Nil): ModuleDef

    Definition Classes
    Unapplies
  60. def companionSymbolOf(original: Symbol, ctx: Context): Symbol

    The companion class or companion module of original.

    The companion class or companion module of original. Calling .companionModule does not work for classes defined inside methods.

    !!! Then why don't we fix companionModule? Does the presence of these methods imply all the places in the compiler calling sym.companionModule are bugs waiting to be reported? If not, why not? When exactly do we need to call this method?

    Definition Classes
    Namers
  61. def computeMacroDefTypeFromMacroImpl(macroDdef: DefDef, macroDef: Symbol, macroImpl: Symbol): Type

    Definition Classes
    Macros
  62. def copyUntyped[T <: Tree](tree: T): T

    Definition Classes
    Unapplies
  63. def copyUntypedInvariant(td: TypeDef): TypeDef

    Definition Classes
    Unapplies
  64. def decodeWithKind(name: Name, owner: Symbol): String

    Definition Classes
    TypeDiagnostics
  65. val deconstMap: TypeMap

  66. def defaultGetter(param: Symbol, context: Context): Symbol

    For a parameter with default argument, find the method symbol of the default getter.

    For a parameter with default argument, find the method symbol of the default getter.

    Definition Classes
    NamesDefaults
  67. val defaultParametersOfMethod: Map[Symbol, Set[WeakReference[Symbol]]]

    Definition Classes
    NamesDefaults
  68. def disambiguate(ss: List[String]): List[String]

    Definition Classes
    TypeDiagnostics
  69. def enclosingMacroPosition: Position

    Definition Classes
    Macros
  70. def ensuring(cond: (Erasure) ⇒ Boolean, msg: ⇒ Any): Erasure

    Implicit information
    This member is added by an implicit conversion from Erasure to Ensuring[Erasure] performed by method any2Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  71. def ensuring(cond: (Erasure) ⇒ Boolean): Erasure

    Implicit information
    This member is added by an implicit conversion from Erasure to Ensuring[Erasure] performed by method any2Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  72. def ensuring(cond: Boolean, msg: ⇒ Any): Erasure

    Implicit information
    This member is added by an implicit conversion from Erasure to Ensuring[Erasure] performed by method any2Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  73. def ensuring(cond: Boolean): Erasure

    Implicit information
    This member is added by an implicit conversion from Erasure to Ensuring[Erasure] performed by method any2Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  74. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  75. def equals(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  76. def erasedTypeRef(sym: Symbol): Type

    Type reference after erasure

    Type reference after erasure

    Definition Classes
    Erasure
  77. def erasure(sym: Symbol): ErasureMap

    The erasure |T| of a type T.

    The erasure |T| of a type T. This is:

    • For a constant type, itself.
    • For a type-bounds structure, the erasure of its upper bound.
    • For every other singleton type, the erasure of its supertype.
    • For a typeref scala.Array+[T] where T is an abstract type, AnyRef.
    • For a typeref scala.Array+[T] where T is not an abstract type, scala.Array+[|T|].
    • For a typeref scala.Any or scala.AnyVal, java.lang.Object.
    • For a typeref scala.Unit, scala.runtime.BoxedUnit.
    • For a typeref P.C[Ts] where C refers to a class, |P|.C. (Where P is first rebound to the class that directly defines C.)
    • For a typeref P.C[Ts] where C refers to an alias type, the erasure of C's alias.
    • For a typeref P.C[Ts] where C refers to an abstract type, the erasure of C's upper bound.
    • For a non-empty type intersection (possibly with refinement)
      • in scala, the erasure of the intersection dominator
      • in java, the erasure of its first parent <--- @PP: not yet in spec.
    • For an empty type intersection, java.lang.Object.
    • For a method type (Fs)scala.Unit, (|Fs|)scala#Unit.
    • For any other method type (Fs)Y, (|Fs|)|T|.
    • For a polymorphic type, the erasure of its result type.
    • For the class info type of java.lang.Object, the same type without any parents.
    • For a class info type of a value class, the same type without any parents.
    • For any other class info type with parents Ps, the same type with parents |Ps|, but with duplicate references of Object removed.
    • for all other types, the type itself (with any sub-components erased)
    Definition Classes
    Erasure
  78. def etaExpand(unit: CompilationUnit, tree: Tree): Tree

    Expand partial function applications of type type.

    Expand partial function applications of type type.

     p.f(es_1)...(es_n)
        ==>  {
               private synthetic val eta$f   = p.f   // if p is not stable
               ...
               private synthetic val eta$e_i = e_i    // if e_i is not stable
               ...
               (ps_1 => ... => ps_m => eta$f([es_1])...([es_m])(ps_1)...(ps_m))
             }
    

    tree is already attributed

    Definition Classes
    EtaExpansion
  79. object etaExpansion extends AnyRef

  80. def existentialContext(tp: Type): String

    Definition Classes
    TypeDiagnostics
  81. def explainAlias(tp: Type): String

    Definition Classes
    TypeDiagnostics
  82. def explainVariance(found: Type, req: Type): String

    Look through the base types of the found type for any which might have been valid subtypes if given conformant type arguments.

    Look through the base types of the found type for any which might have been valid subtypes if given conformant type arguments. Examine those for situations where the type error would have been eliminated if the variance were different. In such cases, append an additional explanatory message.

    TODO: handle type aliases better.

    Definition Classes
    TypeDiagnostics
  83. def factoryMeth(mods: Modifiers, name: TermName, cdef: ClassDef, symbolic: Boolean): DefDef

    The apply method corresponding to a case class

    The apply method corresponding to a case class

    Definition Classes
    Unapplies
  84. def finalize(): Unit

    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws()
  85. final def forArgMode(fun: Tree, mode: Int): Int

    Definition Classes
    Typers
  86. final def forFunMode(mode: Int): Int

    Definition Classes
    Modes
  87. final def forTypeMode(mode: Int): Int

    Definition Classes
    Modes
  88. def formalTypes(formals: List[Type], nargs: Int, removeByName: Boolean = true, removeRepeated: Boolean = true): List[Type]

    The formal parameter types corresponding to formals.

    The formal parameter types corresponding to formals. If formals has a repeated last parameter, a list of (nargs - params.length + 1) copies of its type is returned. By-name types are replaced with their underlying type.

    removeByName

    allows keeping ByName parameters. Used in NamesDefaults.

    removeRepeated

    allows keeping repeated parameter (if there's one argument). Used in NamesDefaults.

    Definition Classes
    Infer
  89. def formatted(fmtstr: String): String

    Implicit information
    This member is added by an implicit conversion from Erasure to StringFormat performed by method any2stringfmt in scala.Predef.
    Definition Classes
    StringFormat
    Annotations
    @inline()
  90. def foundReqMsg(found: Type, req: Type): String

    Definition Classes
    TypeDiagnostics
  91. def freshVar(tparam: Symbol): TypeVar

    A fresh type variable with given type parameter as origin.

    A fresh type variable with given type parameter as origin.

    tparam

    ...

    returns

    ...

    Definition Classes
    Infer
  92. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  93. val globalMacroCache: Map[Any, Any]

    Definition Classes
    Macros
  94. def globalSettings: Settings

    Definition Classes
    MacrosTraces
  95. var hasPendingMacroExpansions: Boolean

    Without any restrictions on macro expansion, macro applications will expand at will, and when type inference is involved, expansions will end up using yet uninferred type params.

    Without any restrictions on macro expansion, macro applications will expand at will, and when type inference is involved, expansions will end up using yet uninferred type params.

    For some macros this might be ok (thanks to TreeTypeSubstituter that replaces the occurrences of undetparams with their inferred values), but in general case this won't work. E.g. for reification simple substitution is not enough - we actually need to re-reify inferred types.

    Luckily, there exists a very simple way to fix the problem: delay macro expansion until everything is inferred. Here are the exact rules. Macro application gets delayed if any of its subtrees contain: 1) type vars (tpe.isInstanceOf[TypeVar]) // [Eugene] this check is disabled right now, because TypeVars seem to be created from undetparams anyways 2) undetparams (sym.isTypeParameter && !sym.isSkolem)

    Definition Classes
    Macros
  96. def hashCode(): Int

    SubComponent are added to a HashSet and two phases are the same if they have the same name

    SubComponent are added to a HashSet and two phases are the same if they have the same name

    Definition Classes
    SubComponent → AnyRef → Any
  97. def implClass(iface: Symbol): Symbol

    Return the implementation class of a trait; create a new one of one does not yet exist

    Return the implementation class of a trait; create a new one of one does not yet exist

    Definition Classes
    AddInterfaces
  98. def implClassDefs(trees: List[Tree]): List[Tree]

    Definition Classes
    AddInterfaces
  99. def implClassPhase: Phase

    Definition Classes
    AddInterfaces
  100. final def inAllModes(mode: Int, required: Int): Boolean

    Definition Classes
    Modes
  101. final def inAnyMode(mode: Int, required: Int): Boolean

    Definition Classes
    Modes
  102. final def inExprModeButNot(mode: Int, prohibited: Int): Boolean

    Definition Classes
    Modes
  103. final def inFunMode(mode: Int): Boolean

    Definition Classes
    Modes
  104. final def inHKMode(mode: Int): Boolean

    Definition Classes
    Modes
  105. final def inNoModes(mode: Int, prohibited: Int): Boolean

    Definition Classes
    Modes
  106. final def inPatternMode(mode: Int): Boolean

    Definition Classes
    Modes
  107. final def inPolyMode(mode: Int): Boolean

    Definition Classes
    Modes
  108. def inferImplicit(tree: Tree, pt: Type, reportAmbiguous: Boolean, isView: Boolean, context: Context, saveAmbiguousDivergent: Boolean, pos: Position): SearchResult

    Search for an implicit value.

    Search for an implicit value. See the comment on result at the end of class ImplicitSearch for more info how the search is conducted.

    tree

    The tree for which the implicit needs to be inserted. (the inference might instantiate some of the undetermined type parameters of that tree.

    pt

    The expected type of the implicit.

    reportAmbiguous

    Should ambiguous implicit errors be reported? False iff we search for a view to find out whether one type is coercible to another.

    isView

    We are looking for a view

    context

    The current context

    saveAmbiguousDivergent

    False if any divergent/ambiguous errors should be ignored after implicits search, true if they should be reported (used in further typechecking).

    pos

    Position that is should be used for tracing and error reporting (useful when we infer synthetic stuff and pass EmptyTree in the tree argument) If it's set NoPosition, then position-based services will use tree.pos

    returns

    A search result

    Definition Classes
    Implicits
  109. def inferImplicit(tree: Tree, pt: Type, reportAmbiguous: Boolean, isView: Boolean, context: Context, saveAmbiguousDivergent: Boolean): SearchResult

    Definition Classes
    Implicits
  110. def inferImplicit(tree: Tree, pt: Type, reportAmbiguous: Boolean, isView: Boolean, context: Context): SearchResult

    Definition Classes
    Implicits
  111. object instantiate extends TypeMap

    Map every TypeVar to its constraint.

  112. val internal: Boolean

    Internal flag to tell external from internal phases

    Internal flag to tell external from internal phases

    Definition Classes
    SubComponent
  113. def intersectionDominator(parents: List[Type]): Type

    The intersection dominator (SLS 3.

    The intersection dominator (SLS 3.7) of a list of types is computed as follows.

    • If the list contains one or more occurrences of scala.Array with type parameters El1, El2, ... then the dominator is scala.Array with type parameter of intersectionDominator(List(El1, El2, ...)). <--- @PP: not yet in spec.
    • Otherwise, the list is reduced to a subsequence containing only types which are not subtypes of other listed types (the span.)
    • If the span is empty, the dominator is Object.
    • If the span contains a class Tc which is not a trait and which is not Object, the dominator is Tc. <--- @PP: "which is not Object" not in spec.
    • Otherwise, the dominator is the first element of the span.
    Definition Classes
    Erasure
  114. def isIdentity(a: Array[Int]): Boolean

    returns true if every element is equal to its index

    returns true if every element is equal to its index

    Definition Classes
    NamesDefaults
  115. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  116. def isNamed(arg: Tree): Boolean

    Definition Classes
    NamesDefaults
  117. def isValidSignature(sym: Symbol, sig: String): Boolean

    Run the signature parser to catch bogus signatures.

  118. object javaErasure extends JavaErasureMap

  119. def javaSig(sym0: Symbol, info: Type): Option[String]

    The Java signature of type 'info', for symbol sym.

    The Java signature of type 'info', for symbol sym. The symbol is used to give the right return type for constructors.

  120. def keepsTypeParams: Boolean

    Definition Classes
    ErasureInfoTransform
  121. var lastAccessCheckDetails: String

    Definition Classes
    Contexts
  122. def linePrecedes(t1: Tree, t2: Tree): Boolean

    Definition Classes
    TypeDiagnostics
  123. def lockedCount: Int

    Definition Classes
    Namers
  124. def macroContext(typer: Typer, prefixTree: Tree, expandeeTree: Tree): Context { val mirror: Erasure.this.global.type }

    Should become private again once we're done with migrating typetag generation from implicits

    Should become private again once we're done with migrating typetag generation from implicits

    Definition Classes
    Macros
  125. val macroDebugLite: Boolean

    Definition Classes
    Traces
  126. val macroDebugVerbose: Boolean

    Definition Classes
    Traces
  127. def macroExpand(typer: Typer, expandee: Tree, mode: Int = EXPRmode, pt: Type = WildcardType): Tree

    Performs macro expansion: 1) Checks whether the expansion needs to be delayed (see mustDelayMacroExpansion) 2) Loads macro implementation using macroMirror 3) Synthesizes invocation arguments for the macro implementation 4) Checks that the result is a tree bound to this universe 5) Typechecks the result against the return type of the macro definition

    Performs macro expansion: 1) Checks whether the expansion needs to be delayed (see mustDelayMacroExpansion) 2) Loads macro implementation using macroMirror 3) Synthesizes invocation arguments for the macro implementation 4) Checks that the result is a tree bound to this universe 5) Typechecks the result against the return type of the macro definition

    If -Ymacro-debug-lite is enabled, you will get basic notifications about macro expansion along with macro expansions logged in the form that can be copy/pasted verbatim into REPL.

    If -Ymacro-debug-verbose is enabled, you will get detailed log of how exactly this function performs class loading and method resolution in order to load the macro implementation. The log will also include other non-trivial steps of macro expansion.

    @return the expansion result if the expansion has been successful, the fallback method invocation if the expansion has been unsuccessful, but there is a fallback, the expandee unchanged if the expansion has been delayed, the expandee fully expanded if the expansion has been delayed before and has been expanded now, the expandee with an error marker set if the expansion has been cancelled due malformed arguments or implementation the expandee with an error marker set if there has been an error

    Definition Classes
    Macros
  128. def macroExpandAll(typer: Typer, expandee: Tree): Tree

    Performs macro expansion on all subtrees of a given tree.

    Performs macro expansion on all subtrees of a given tree. Innermost macros are expanded first, outermost macros are expanded last. See the documentation for macroExpand for more information.

    Definition Classes
    Macros
  129. final def macroLogLite(msg: ⇒ Any): Unit

    Definition Classes
    Traces
    Annotations
    @inline()
  130. final def macroLogVerbose(msg: ⇒ Any): Unit

    Definition Classes
    Traces
    Annotations
    @inline()
  131. val macroTraceLite: SimpleTracer

    Definition Classes
    Traces
  132. val macroTraceVerbose: SimpleTracer

    Definition Classes
    Traces
  133. def memberWildcardType(name: Name, tp: Type): Type

    A constructor for types ?{ name: tp }, used in infer view to member searches.

    A constructor for types ?{ name: tp }, used in infer view to member searches.

    Definition Classes
    Implicits
  134. def missingParams[T](args: List[T], params: List[Symbol], argName: (T) ⇒ Option[Name]): (List[Symbol], Boolean)

    Definition Classes
    NamesDefaults
  135. val mixinTransformer: Transformer

    Attributes
    protected
    Definition Classes
    AddInterfaces
  136. def mkTypeCompleter(t: Tree)(c: (Symbol) ⇒ Unit): TypeCompleter with LockingTypeCompleter

    Definition Classes
    Namers
  137. def modeString(mode: Int): String

    Definition Classes
    Modes
  138. def nameOf(arg: Tree): Option[Name]

    Definition Classes
    NamesDefaults
  139. object namerFactory extends SubComponent

  140. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  141. def needsJavaSig(tp: Type): Boolean

  142. def newNamer(context: Context): Namer

    Definition Classes
    Namers
  143. def newNamerFor(context: Context, tree: Tree): Namer

    Definition Classes
    Namers
  144. def newPhase(prev: Phase): StdPhase

    Create a new phase which applies transformer

    Create a new phase which applies transformer

    Definition Classes
    AddInterfacesInfoTransformTransformSubComponent
  145. def newTransformer(unit: CompilationUnit): Transformer

    The transformer factory

    The transformer factory

    Definition Classes
    ErasureTransform
  146. def newTyper(context: Context): Eraser

    Definition Classes
    ErasureTypers
  147. val noApplyInfo: NamedApplyInfo

    Definition Classes
    NamesDefaults
  148. def noErroneousSyms(syms: Symbol*): Boolean

    Definition Classes
    TypeDiagnostics
  149. def noErroneousTrees(trees: Tree*): Boolean

    Definition Classes
    TypeDiagnostics
  150. def noErroneousTypes(tps: Type*): Boolean

    The common situation of making sure nothing is erroneous could be nicer if Symbols, Types, and Trees all implemented some common interface in which isErroneous and similar would be placed.

    The common situation of making sure nothing is erroneous could be nicer if Symbols, Types, and Trees all implemented some common interface in which isErroneous and similar would be placed.

    Definition Classes
    TypeDiagnostics
  151. def normalize(tp: Type): Type

    Automatically perform the following conversions on expression types: A method type becomes the corresponding function type.

    Automatically perform the following conversions on expression types: A method type becomes the corresponding function type. A nullary method type becomes its result type. Implicit parameters are skipped. This method seems to be performance critical.

    Definition Classes
    Infer
  152. final def notify(): Unit

    Definition Classes
    AnyRef
  153. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  154. def notifyUndetparamsAdded(newUndets: List[Symbol]): Unit

    Definition Classes
    Macros
  155. def notifyUndetparamsInferred(undetNoMore: List[Symbol], inferreds: List[Type]): Unit

    Definition Classes
    Macros
  156. def numericConversion(tree: Tree, numericSym: Symbol): Tree

  157. final def onlyStickyModes(mode: Int): Int

    Definition Classes
    Modes
  158. var openMacros: List[Context]

    Keeps track of macros in-flight.

    Keeps track of macros in-flight. See more informations in comments to openMacros in scala.reflect.makro.Context.

    Definition Classes
    Macros
  159. def ownPhase: Phase

    The phase corresponding to this subcomponent in the current compiler run

    The phase corresponding to this subcomponent in the current compiler run

    Definition Classes
    SubComponent
  160. object packageObjects extends SubComponent

  161. val perRunMacroCache: HashMap[Symbol, Map[Any, Any]]

    Definition Classes
    Macros
  162. val phaseName: String

    The name of the phase

    The name of the phase

    Definition Classes
    ErasureSubComponent
  163. def phaseNewFlags: Long

    The phase sets lateINTERFACE for non-interface traits that now become interfaces.

    The phase sets lateINTERFACE for non-interface traits that now become interfaces. It sets lateDEFERRED for formerly concrete methods in such traits.

    Definition Classes
    AddInterfacesSubComponent
  164. def phaseNextFlags: Long

    New flags defined by the phase which are not valid until immediately after it

    New flags defined by the phase which are not valid until immediately after it

    Definition Classes
    SubComponent
  165. def posPrecedes(p1: Position, p2: Position): Boolean

    Does the positioned line assigned to t1 precede that of t2?

    Does the positioned line assigned to t1 precede that of t2?

    Definition Classes
    TypeDiagnostics
  166. val prepareSigMap: TypeMap { def squashBoxed(tp: Erasure.this.global.Type): Erasure.this.global.Type }

    This object is only used for sanity testing when -check:genjvm is set.

    This object is only used for sanity testing when -check:genjvm is set. In that case we make sure that the erasure of the normalized type is the same as the erased type that's generated. Normalization means unboxing some primitive types and further simplifications as they are done in jsig.

  167. def rebindInnerClass(pre: Type, cls: Symbol): Type

    Attributes
    protected
    Definition Classes
    Erasure
  168. def removeNames(typer: Typer)(args: List[Tree], params: List[Symbol]): (List[Tree], Array[Int])

    Removes name assignments from args.

    Removes name assignments from args. Additionally, returns an array mapping argument indices from call-site-order to definition-site-order.

    Verifies that names are not specified twice, positional args don't appear after named ones.

    Definition Classes
    NamesDefaults
  169. def reorderArgs[T](args: List[T], pos: (Int) ⇒ Int)(implicit arg0: ArrayTag[T]): List[T]

    pos

    maps indices from old to new

    Definition Classes
    NamesDefaults
  170. def reorderArgsInv[T](args: List[T], pos: (Int) ⇒ Int)(implicit arg0: ArrayTag[T]): List[T]

    pos

    maps indices from new to old (!)

    Definition Classes
    NamesDefaults
  171. def resetContexts(): Unit

    Definition Classes
    Contexts
  172. def resetImplicits(): Unit

    Definition Classes
    Implicits
  173. def resetNamer(): Unit

    Definition Classes
    Namers
  174. def resetTyper(): Unit

    Definition Classes
    Typers
  175. def restrictionError(pos: Position, unit: CompilationUnit, msg: String): Unit

    Definition Classes
    TypeDiagnostics
  176. def restrictionWarning(pos: Position, unit: CompilationUnit, msg: String): Unit

    For errors which are artifacts of the implementation: such messages indicate that the restriction may be lifted in the future.

    For errors which are artifacts of the implementation: such messages indicate that the restriction may be lifted in the future.

    Definition Classes
    TypeDiagnostics
  177. def rootContext(unit: CompilationUnit, tree: Tree, erasedTypes: Boolean): Context

    Definition Classes
    Contexts
  178. def rootContext(unit: CompilationUnit, tree: Tree): Context

    Definition Classes
    Contexts
  179. def rootContext(unit: CompilationUnit): Context

    Definition Classes
    Contexts
  180. def rootImports(unit: CompilationUnit): List[Symbol]

    List of symbols to import from in a root context.

    List of symbols to import from in a root context. Typically that is java.lang, scala, and scala.Predef, in that order. Exceptions:

    • if option -Yno-imports is given, nothing is imported
    • if the unit is java defined, only java.lang is imported
    • if option -Yno-predef is given, if the unit body has an import of Predef among its leading imports, or if the tree is scala.Predef, Predef is not imported.
    Attributes
    protected
    Definition Classes
    Contexts
  181. val runsBefore: List[String]

    List of phase names, this phase should run before

    List of phase names, this phase should run before

    Definition Classes
    SubComponent
  182. object scalaErasure extends ScalaErasureMap

  183. val self: Any

    Implicit information
    This member is added by an implicit conversion from Erasure to StringFormat performed by method any2stringfmt in scala.Predef.
    Definition Classes
    StringFormat
  184. val self: Any

    Implicit information
    This member is added by an implicit conversion from Erasure to StringAdd performed by method any2stringadd in scala.Predef.
    Definition Classes
    StringAdd
  185. def setAddendum(pos: Position, msg: () ⇒ String): Unit

    Definition Classes
    TypeDiagnostics
  186. final val shortenImports: Boolean(false)

    Definition Classes
    Typers
  187. def skipImplicit(tp: Type): Type

    Definition Classes
    Infer
  188. def solvedTypes(tvars: List[TypeVar], tparams: List[Symbol], variances: List[Int], upper: Boolean, depth: Int): List[Type]

    Solve constraint collected in types tvars.

    Solve constraint collected in types tvars.

    tvars

    All type variables to be instantiated.

    tparams

    The type parameters corresponding to tvars

    variances

    The variances of type parameters; need to reverse solution direction for all contravariant variables.

    upper

    When true search for max solution else min.

    Definition Classes
    Infer
    Exceptions thrown
    NoInstance

  189. def specialErasure(sym: Symbol)(tp: Type): Type

    This is used as the Scala erasure during the erasure phase itself It differs from normal erasure in that value classes are erased to ErasedValueTypes which are then later converted to the underlying parameter type in phase posterasure.

    This is used as the Scala erasure during the erasure phase itself It differs from normal erasure in that value classes are erased to ErasedValueTypes which are then later converted to the underlying parameter type in phase posterasure.

    Definition Classes
    Erasure
  190. def specialErasureAvoiding(clazz: Symbol, tpe: Type): Type

    Definition Classes
    Erasure
  191. object specialScalaErasure extends ScalaErasureMap

    This is used as the Scala erasure during the erasure phase itself It differs from normal erasure in that value classes are erased to ErasedValueTypes which are then later converted to the underlying parameter type in phase posterasure.

  192. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  193. object synthesisUtil extends AnyRef

  194. def toString(): String

    Definition Classes
    AnyRef → Any
  195. val traceSignatures: Boolean

  196. def transformInfo(sym: Symbol, tp: Type): Type

    The symbol's erased info.

    The symbol's erased info. This is the type's erasure, except for the following symbols:

    • For $asInstanceOf : [T]T
    • For $isInstanceOf : [T]scala#Boolean
    • For class Array : [T]C where C is the erased classinfo of the Array class.
    • For Array[T].<init> : {scala#Int)Array[T]
    • For a type parameter : A type bounds type consisting of the erasures of its bounds.
    Definition Classes
    ErasureErasureInfoTransform
  197. def transformMixinInfo(tp: Type): Type

    Definition Classes
    AddInterfaces
  198. def transformNamedApplication(typer: Typer, mode: Int, pt: Type)(tree: Tree, argPos: (Int) ⇒ Int): Tree

    Transform a function application into a Block, and assigns typer.

    Transform a function application into a Block, and assigns typer.context .namedApplyBlockInfo to the new block as side-effect. If tree has the form Apply(fun, args) first the function "fun" (which might be an application itself!) is transformed into a block of the form { val qual$1 = qualifier_of_fun val x$1 = arg_1_of_fun ... val x$n = arg_n_of_fun qual$1.fun[targs](x$1, ...)...(..., x$n) } then for each argument in args, a value is created and entered into the block. finally the application expression of the block is updated. { val qual$1 = .. ... val x$n = ... > val qual$n+1 = arg(1) > ... > val qual$n+m = arg(m) > qual$1.fun[targs](x$1, ...)...(..., x$n)(x$n+1, ..., x$n+m) }

    typer

    the typer calling this method; this method calls typer.doTypedApply

    mode

    the mode to use for calling typer.doTypedApply

    pt

    the expected type for calling typer.doTypedApply

    returns

    the transformed application (a Block) together with the NamedApplyInfo. if isNamedApplyBlock(tree), returns the existing context.namedApplyBlockInfo

    Definition Classes
    NamesDefaults
  199. val transformed: HashMap[Tree, Tree]

    Definition Classes
    Typers
  200. def treeSymTypeMsg(tree: Tree): String

    Definition Classes
    TypeDiagnostics
  201. def typedMacroBody(typer: Typer, ddef: DefDef): Tree

    As specified above, body of a macro definition must reference its implementation.

    As specified above, body of a macro definition must reference its implementation. This function verifies that the body indeed refers to a method, and that the referenced macro implementation is compatible with the given macro definition.

    This means that macro implementation (fooBar in example above) must: 1) Refer to a statically accessible, non-overloaded method. 2) Have the right parameter lists as outlined in the SIP / in the doc comment of this class.

    returns

    typechecked rhs of the given macro definition

    Definition Classes
    Macros
  202. object typerFactory extends SubComponent

  203. def unapplyMember(tp: Type): Symbol

    returns unapply or unapplySeq if available

    returns unapply or unapplySeq if available

    Definition Classes
    Unapplies
  204. def unapplyParameterType(extractor: Symbol): Symbol

    returns unapply member's parameter type.

    returns unapply member's parameter type.

    Definition Classes
    Unapplies
  205. def unapplyReturnTypeExpected(argsLength: Int): Type

    returns type of the unapply method returning T_0.

    returns type of the unapply method returning T_0...T_n for n == 0, boolean for n == 1, Some[T0] else Some[Product[Ti]]

    Definition Classes
    Unapplies
  206. def unapplyTypeList(ufn: Symbol, ufntpe: Type): List[Type]

    returns type list for return type of the extraction

    returns type list for return type of the extraction

    Definition Classes
    Unapplies
  207. def unapplyTypeListFromReturnType(tp1: Type): List[Type]

    (the inverse of unapplyReturnTypeSeq) for type Boolean, returns Nil for type Option[T] or Some[T]:

    (the inverse of unapplyReturnTypeSeq) for type Boolean, returns Nil for type Option[T] or Some[T]:

    • returns T0...Tn if n>0 and T <: Product[T0...Tn]]
    • returns T otherwise
    Definition Classes
    Unapplies
  208. def unapplyTypeListFromReturnTypeSeq(tp1: Type): List[Type]

    let type be the result type of the (possibly polymorphic) unapply method for type Option[T] or Some[T] -returns T0.

    let type be the result type of the (possibly polymorphic) unapply method for type Option[T] or Some[T] -returns T0...Tn-1,Tn* if n>0 and T <: Product[T0...Tn-1,Seq[Tn]]], -returns R* if T = Seq[R]

    Definition Classes
    Unapplies
  209. def unboundedGenericArrayLevel(tp: Type): Int

    Attributes
    protected
    Definition Classes
    Erasure
  210. def underlyingOfValueClass(clazz: Symbol): Type

    Definition Classes
    Erasure
  211. def underlyingSymbol(member: Symbol): Symbol

    The symbol which the given accessor represents (possibly in part).

    The symbol which the given accessor represents (possibly in part). This is used for error messages, where we want to speak in terms of the actual declaration or definition, not in terms of the generated setters and getters.

    Definition Classes
    TypeDiagnostics
  212. def varianceInArgs(tps: List[Type], tparams1: List[Symbol])(tparam: Symbol): Int

    Compute variance of type parameter tparam in all type arguments tps which correspond to formal type parameters tparams1.

    Compute variance of type parameter tparam in all type arguments tps which correspond to formal type parameters tparams1.

    Definition Classes
    Variances
  213. def varianceInAttrib(annot: AnnotationInfo)(tparam: Symbol): Int

    Compute variance of type parameter tparam in type annotation annot.

    Compute variance of type parameter tparam in type annotation annot.

    Definition Classes
    Variances
  214. def varianceInAttribs(annots: List[AnnotationInfo])(tparam: Symbol): Int

    Compute variance of type parameter tparam in all type annotations annots.

    Compute variance of type parameter tparam in all type annotations annots.

    Definition Classes
    Variances
  215. def varianceInSym(sym: Symbol)(tparam: Symbol): Int

    Compute variance of type parameter tparam in type of symbol sym.

    Compute variance of type parameter tparam in type of symbol sym.

    Definition Classes
    Variances
  216. def varianceInSyms(syms: List[Symbol])(tparam: Symbol): Int

    Compute variance of type parameter tparam in types of all symbols sym.

    Compute variance of type parameter tparam in types of all symbols sym.

    Definition Classes
    Variances
  217. def varianceInType(tp: Type)(tparam: Symbol): Int

    Compute variance of type parameter tparam in type tp.

    Compute variance of type parameter tparam in type tp.

    Definition Classes
    Variances
  218. def varianceInTypes(tps: List[Type])(tparam: Symbol): Int

    Compute variance of type parameter tparam in all types tps.

    Compute variance of type parameter tparam in all types tps.

    Definition Classes
    Variances
  219. def varianceWord(sym: Symbol): String

    Definition Classes
    TypeDiagnostics
  220. object verifiedJavaErasure extends JavaErasureMap

  221. def verifyJavaErasure: Boolean

    Attributes
    protected
    Definition Classes
    ErasureErasure
  222. object vpmName extends AnyRef

  223. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  224. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  225. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  226. def withAddendum(pos: Position): (String) ⇒ String

    Definition Classes
    TypeDiagnostics
  227. def withDisambiguation[T](locals: List[Symbol], types: Type*)(op: ⇒ T): T

    Given any number of types, alters the name information in the symbols until they can be distinguished from one another: then executes the given code.

    Given any number of types, alters the name information in the symbols until they can be distinguished from one another: then executes the given code. The names are restored and the result is returned.

    Definition Classes
    TypeDiagnostics
  228. def [B](y: B): (Erasure, B)

    Implicit information
    This member is added by an implicit conversion from Erasure to ArrowAssoc[Erasure] performed by method any2ArrowAssoc in scala.Predef.
    Definition Classes
    ArrowAssoc

Deprecated Value Members

  1. def companionClassOf(module: Symbol, ctx: Context): Symbol

    Definition Classes
    Namers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use companionSymbolOf instead

  2. def companionModuleOf(clazz: Symbol, ctx: Context): Symbol

    Definition Classes
    Namers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use companionSymbolOf instead

  3. def underlying(member: Symbol): Symbol

    Definition Classes
    Namers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use underlyingSymbol instead

  4. def x: Erasure

    Implicit information
    This member is added by an implicit conversion from Erasure to ArrowAssoc[Erasure] performed by method any2ArrowAssoc in scala.Predef.
    Definition Classes
    ArrowAssoc
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use leftOfArrow instead

  5. def x: Erasure

    Implicit information
    This member is added by an implicit conversion from Erasure to Ensuring[Erasure] performed by method any2Ensuring in scala.Predef.
    Definition Classes
    Ensuring
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use resultOfEnsuring instead

Inherited from TypingTransformers

Inherited from Analyzer

Inherited from StdAttachments

Inherited from ContextErrors

Inherited from TypeDiagnostics

Inherited from NamesDefaults

Inherited from Macros

Inherited from Traces

Inherited from Unapplies

Inherited from SyntheticMethods

Inherited from EtaExpansion

Inherited from Variances

Inherited from Implicits

Inherited from Infer

Inherited from Typers

Inherited from PatMatVirtualiser

Inherited from TreeDSL

Inherited from Taggings

Inherited from Adaptations

Inherited from Modes

Inherited from Namers

Inherited from MethodSynthesis

Inherited from Contexts

Inherited from Erasure

Inherited from AddInterfaces

Inherited from InfoTransform

Inherited from Transform

Inherited from SubComponent

Inherited from AnyRef

Inherited from Any

Inherited by implicit conversion any2stringfmt from Erasure to StringFormat

Inherited by implicit conversion any2stringadd from Erasure to StringAdd

Inherited by implicit conversion any2ArrowAssoc from Erasure to ArrowAssoc[Erasure]

Inherited by implicit conversion any2Ensuring from Erasure to Ensuring[Erasure]