scala.tools.nsc.typechecker

Analyzer

trait Analyzer extends Contexts with Namers with Typers with Infer with Implicits with EtaExpansion with SyntheticMethods with Unapplies with Macros with NamesDefaults with TypeDiagnostics with ContextErrors with StdAttachments with AnalyzerPlugins

The main attribution phase.

Linear Supertypes
Known Subclasses
Type Hierarchy Learn more about scaladoc diagrams
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. Analyzer
  2. AnalyzerPlugins
  3. StdAttachments
  4. ContextErrors
  5. TypeDiagnostics
  6. NamesDefaults
  7. Macros
  8. Helpers
  9. Traces
  10. MacroRuntimes
  11. ScalaReflectionRuntimes
  12. JavaReflectionRuntimes
  13. FastTrack
  14. Unapplies
  15. SyntheticMethods
  16. TreeDSL
  17. EtaExpansion
  18. Implicits
  19. Infer
  20. Checkable
  21. Typers
  22. Tags
  23. Adaptations
  24. Namers
  25. MethodSynthesis
  26. Contexts
  27. AnyRef
  28. Any
Implicitly
  1. by StringAdd
  2. by StringFormat
  3. by Ensuring
  4. by ArrowAssoc
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Type Members

  1. sealed abstract class AbsTypeError extends Throwable

    Definition Classes
    ContextErrors
  2. case class AccessTypeError(underlyingTree: Global.Tree, errMsg: String) extends Analyzer.TreeTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  3. trait Adaptation extends AnyRef

    Definition Classes
    Adaptations
  4. case class AmbiguousImplicitTypeError(underlyingTree: Global.Tree, errMsg: String) extends Analyzer.TreeTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  5. case class AmbiguousTypeError(errPos: Global.Position, errMsg: String) extends Analyzer.AbsTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  6. trait AnalyzerPlugin extends AnyRef

    Definition Classes
    AnalyzerPlugins
  7. class ClassForCaseCompanionAttachment extends AnyRef

    Definition Classes
    Unapplies
  8. class ClassMethodSynthesis extends AnyRef

    Definition Classes
    MethodSynthesis
  9. class ConstructorDefaultsAttachment extends AnyRef

    Definition Classes
    NamesDefaults
  10. class Context extends AnyRef

    A motley collection of the state and loosely associated behaviour of the type checker.

  11. class DefaultsOfLocalMethodAttachment extends AnyRef

    Definition Classes
    NamesDefaults
  12. case class DivergentImplicitTypeError(underlyingTree: Global.Tree, pt0: Global.Type, sym: Global.Symbol) extends Analyzer.TreeTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  13. final class FastTrackEntry extends ((FastTrack.this)#MacroArgs) ⇒ Any

    Definition Classes
    FastTrack
  14. class ImplicitInfo extends AnyRef

    A class that records an available implicit

  15. class ImplicitSearch extends Analyzer.Typer with Analyzer.ImplicitsContextErrors

    A class that sets up an implicit search.

  16. trait ImplicitsContextErrors extends AnyRef

    Definition Classes
    ContextErrors
  17. trait ImportContext extends Analyzer.Context

    A Context focussed on an Import tree

  18. class ImportInfo extends AnyRef

    Definition Classes
    Contexts
  19. case class ImportType(expr: Global.Tree) extends Global.Type with Product with Serializable

    Definition Classes
    Contexts
  20. trait InferCheckable extends AnyRef

    Definition Classes
    Checkable
  21. class Inferencer extends Analyzer.InferencerContextErrors with Analyzer.InferCheckable

    The context-dependent inferencer part

  22. trait InferencerContextErrors extends AnyRef

    Definition Classes
    ContextErrors
  23. trait JavaReflectionResolvers extends AnyRef

    Definition Classes
    JavaReflectionRuntimes
  24. trait LockingTypeCompleter extends Analyzer.TypeCompleter

    Definition Classes
    Namers
  25. case class MacroArgs(c: Analyzer.MacroContext, others: List[Any]) extends Product with Serializable

    Calculate the arguments to pass to a macro implementation when expanding the provided tree.

  26. type MacroContext = UnaffiliatedMacroContext { val universe: Analyzer.this.global.type }

    Definition Classes
    StdAttachments
  27. case class MacroExpanderAttachment(original: Global.Tree, desugared: Global.Tree, role: Analyzer.MacroRole) extends Product with Serializable

    Scratchpad for the macro expander, which is used to store all intermediate data except the details about the runtime.

  28. case class MacroExpansionAttachment(expandee: Global.Tree, expanded: Any) extends Product with Serializable

    Is added by the macro engine to originals and results of macro expansions.

  29. case class MacroImplBinding(isBundle: Boolean, className: String, methName: String, signature: List[List[Fingerprint]], targs: List[Global.Tree]) extends Product with Serializable

    Represents all the information that a macro definition needs to know about its implementation.

  30. type MacroRole = typechecker.MacroRole

    Describes the role that the macro expandee is performing.

    Describes the role that the macro expandee is performing.

    Definition Classes
    Macros
  31. type MacroRuntime = (MacroArgs) ⇒ Any

    Abstracts away resolution of macro runtimes.

    Abstracts away resolution of macro runtimes.

    Definition Classes
    MacroRuntimes
  32. case class MacroRuntimeAttachment(delayed: Boolean, typerContext: Analyzer.Context, macroContext: Option[Analyzer.MacroContext]) extends Product with Serializable

    Definition Classes
    StdAttachments
  33. class MacroRuntimeResolver extends tools.nsc.typechecker.Analyzer.JavaReflectionResolvers with tools.nsc.typechecker.Analyzer.ScalaReflectionResolvers

    Definition Classes
    MacroRuntimes
  34. trait MethodSynth extends AnyRef

    There are two key methods in here.

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

    Definition Classes
    NamesDefaults
  36. abstract class Namer extends Analyzer.MethodSynth with Analyzer.NamerContextErrors

    Definition Classes
    Namers
  37. trait NamerContextErrors extends AnyRef

    Definition Classes
    ContextErrors
  38. class NoInstance extends Throwable with ControlThrowable

    Definition Classes
    Infer
  39. case class NormalTypeError(underlyingTree: Global.Tree, errMsg: String) extends Analyzer.TreeTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  40. case class OpenImplicit(info: Analyzer.ImplicitInfo, pt: Global.Type, tree: Global.Tree) extends Product with Serializable

    A class which is used to track pending implicits to prevent infinite implicit searches.

  41. class PolyTypeCompleter extends Analyzer.TypeCompleter with Analyzer.LockingTypeCompleter with Global.FlagAgnosticCompleter

    A class representing a lazy type with known type parameters.

  42. case class PosAndMsgTypeError(errPos: Global.Position, errMsg: String) extends Analyzer.AbsTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  43. final class ReportBuffer extends AnyRef

    A buffer for warnings and errors that are accumulated during speculative type checking.

  44. trait ScalaReflectionResolvers extends AnyRef

    Definition Classes
    ScalaReflectionRuntimes
  45. class SearchResult extends AnyRef

    The result of an implicit search

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

    Definition Classes
    Typers
  47. case class SilentResultValue[+T](value: T) extends Analyzer.SilentResult[T] with Product with Serializable

    Definition Classes
    Typers
  48. case class SilentTypeError(err: Analyzer.AbsTypeError) extends Analyzer.SilentResult[Nothing] with Product with Serializable

    Definition Classes
    Typers
  49. case class SuperArgsAttachment(argss: List[List[Global.Tree]]) extends Product with Serializable

    After being synthesized by the parser, primary constructors aren't fully baked yet.

  50. case class SymbolTypeError(underlyingSym: Global.Symbol, errMsg: String) extends Analyzer.AbsTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  51. trait Tag extends AnyRef

    Definition Classes
    Tags
  52. sealed abstract class TreeTypeError extends Analyzer.AbsTypeError

    Definition Classes
    ContextErrors
  53. abstract class TypeCompleter extends Global.LazyType

    Definition Classes
    Namers
  54. case class TypeDiag(tp: Global.Type, sym: Global.Symbol) extends Ordered[Analyzer.TypeDiag] with Product with Serializable

    Definition Classes
    TypeDiagnostics
  55. case class TypeErrorWithUnderlyingTree(tree: Global.Tree, ex: Global.TypeError) extends Analyzer.AbsTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  56. case class TypeErrorWrapper(ex: Global.TypeError) extends Analyzer.AbsTypeError with Product with Serializable

    Definition Classes
    ContextErrors
  57. abstract class Typer extends Analyzer.TyperDiagnostics with Analyzer.Adaptation with Analyzer.Tag with Analyzer.TyperContextErrors

    Definition Classes
    Typers
  58. trait TyperContextErrors extends AnyRef

    Definition Classes
    ContextErrors
  59. trait TyperDiagnostics extends AnyRef

    Definition Classes
    TypeDiagnostics
  60. type UnaffiliatedMacroContext = reflect.macros.contexts.Context

    Carries information necessary to expand the host tree.

    Carries information necessary to expand the host tree. At times we need to store this info, because macro expansion can be delayed until its targs are inferred. After a macro application has been successfully expanded, this attachment is destroyed.

    Definition Classes
    StdAttachments

Abstract Value Members

  1. abstract val global: Global

    Definition Classes
    AnalyzerTreeDSL

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 Analyzer to StringAdd[Analyzer] performed by method StringAdd in scala.Predef.
    Definition Classes
    StringAdd
  5. def ->[B](y: B): (Analyzer, B)

    Implicit information
    This member is added by an implicit conversion from Analyzer to ArrowAssoc[Analyzer] performed by method ArrowAssoc 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 def APPLY_ROLE: typechecker.MacroRole

    Definition Classes
    Macros
  9. lazy val AmbiguousSearchFailure: SearchResult

    Definition Classes
    Implicits
  10. object CODE

    Definition Classes
    TreeDSL
  11. lazy val DivergentSearchFailure: SearchResult

    Definition Classes
    Implicits
  12. object ErrorUtils

    Definition Classes
    ContextErrors
  13. object ExpandedIntoTree

    Checks whether there is any tree resulting from a macro expansion and associated with the current tree.

  14. object ExtractorType

    Definition Classes
    Unapplies
  15. object Function1

    An extractor for unary function types arg => res

  16. object HasMember

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

  17. object HasMethodMatching

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

  18. object ImplicitNotFoundMsg

    Definition Classes
    Implicits
  19. object MacroImplBinding extends Serializable

    Macro def -> macro impl bindings are serialized into a macroImpl annotation with synthetic content that carries the payload described in MacroImplBinding.

  20. object MacroImplRefAttachment extends Product with Serializable

  21. object NamesDefaultsErrorsGen

    Definition Classes
    ContextErrors
  22. object NoContext extends Analyzer.Context

    Definition Classes
    Contexts
  23. val NoImplicitInfo: ImplicitInfo

    A sentinel indicating no implicit was found

    A sentinel indicating no implicit was found

    Definition Classes
    Implicits
  24. lazy val SearchFailure: SearchResult

    Definition Classes
    Implicits
  25. object SuppressMacroExpansionAttachment extends Product with Serializable

    When present, suppresses macro expansion for the host.

  26. final def UNAPPLY_ROLE: typechecker.MacroRole

    Definition Classes
    Macros
  27. object UnTyper extends Global.Traverser

    Definition Classes
    Typers
  28. def abstractVarMessage(sym: Global.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
  29. def adaptAnnotations(tree: Global.Tree, typer: Typer, mode: Mode, pt: Global.Type): Global.Tree

    Definition Classes
    AnalyzerPlugins
    See also

    AnalyzerPlugin.adaptAnnotations

  30. def addAnalyzerPlugin(plugin: AnalyzerPlugin): Unit

    Registers a new analyzer plugin

    Registers a new analyzer plugin

    Definition Classes
    AnalyzerPlugins
  31. def addDefaults(givenArgs: List[Global.Tree], qual: Option[Global.Tree], targs: List[Global.Tree], previousArgss: List[List[Global.Tree]], params: List[Global.Symbol], pos: Position, context: Context): (List[Global.Tree], List[Global.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
  32. def addSyntheticMethods(templ: Global.Template, clazz0: Global.Symbol, context: Context): Global.Template

    Add the synthetic methods to case classes.

    Add the synthetic methods to case classes.

    Definition Classes
    SyntheticMethods
  33. def allArgsArePositional(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
  34. def allViewsFrom(tp: Global.Type, context: Context, tpars: List[Global.Symbol]): List[(SearchResult, List[Global.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
  35. def alternatives(tree: Global.Tree): List[Global.Type]

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

    Definition Classes
    TypeDiagnostics
  37. def ambiguousDefnAndImport(owner: Global.Symbol, imp: ImportInfo): Global.LookupAmbiguous

    Definition Classes
    Contexts
  38. def ambiguousImports(imp1: ImportInfo, imp2: ImportInfo): Global.LookupAmbiguous

    Definition Classes
    Contexts
  39. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  40. def bindMacroImpl(macroDef: Global.Symbol, macroImplRef: Global.Tree): Unit

    Definition Classes
    Macros
  41. def canAdaptAnnotations(tree: Global.Tree, typer: Typer, mode: Mode, pt: Global.Type): Boolean

    Definition Classes
    AnalyzerPlugins
    See also

    AnalyzerPlugin.canAdaptAnnotations

  42. final def caseAccessorName(caseclazz: Global.Symbol, paramName: Global.TermName): Global.TermName

    Does not force the info of caseclazz

    Does not force the info of caseclazz

    Definition Classes
    SyntheticMethods
  43. def caseClassCopyMeth(cdef: Global.ClassDef): Option[Global.DefDef]

    Generates copy methods for case classes.

    Generates copy methods for case classes. Copy only has defaults on the first parameter list, as of SI-5009.

    The parameter types of the copy method need to be exactly the same as the parameter types of the primary constructor. Just copying the TypeTree is not enough: a type C might refer to something else *inside* the class (i.e. as parameter type of copy) than *outside* the class (i.e. in the class parameter list).

    One such example is t0054.scala: class A { case class B(x: C) extends A { def copy(x: C = x) = ... } class C {} } (1) (2)

    The reference (1) to C is A.this.C. The reference (2) is B.this.C - not the same.

    This is fixed with a hack currently. Unapplies.caseClassCopyMeth, which creates the copy method, uses empty TypeTree() nodes for parameter types.

    In Namers.enterDefDef, the copy method gets a special type completer (enterCopyMethod). Before computing the body type of copy, the class parameter types are assigned the copy method parameters.

    This attachment class stores the copy method parameter ValDefs as an attachment in the ClassDef of the case class.

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

    The apply method corresponding to a case class

    The apply method corresponding to a case class

    Definition Classes
    Unapplies
  45. def caseModuleDef(cdef: Global.ClassDef): Global.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
  46. def caseModuleUnapplyMeth(cdef: Global.ClassDef): Global.DefDef

    The unapply method corresponding to a case class

    The unapply method corresponding to a case class

    Definition Classes
    Unapplies
  47. def clone(): AnyRef

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

    Definition Classes
    Unapplies
  49. def companionSymbolOf(original: Global.Symbol, ctx: Context): Global.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
  50. def computeMacroDefTypeFromMacroImplRef(macroDdef: Global.DefDef, macroImplRef: Global.Tree): Global.Type

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

    Definition Classes
    Unapplies
  52. def copyUntypedInvariant(td: Global.TypeDef): Global.TypeDef

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

    Definition Classes
    TypeDiagnostics
  54. def decreaseMetalevel(tp: Global.Type): Global.Type

    Decreases metalevel of the type, i.

    Decreases metalevel of the type, i.e. transforms: * c.Expr[T] to T * Anything else to Any

    Definition Classes
    Helpers
    See also

    Metalevels.scala for more information and examples about metalevels

  55. def defaultGetter(param: Global.Symbol, context: Context): Global.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
  56. lazy val defaultMacroClassloader: ClassLoader

    Macro classloader that is used to resolve and run macro implementations.

    Macro classloader that is used to resolve and run macro implementations. Loads classes from from -cp (aka the library classpath). Is also capable of detecting REPL and reusing its classloader.

    When -Xmacro-jit is enabled, we sometimes fallback to on-the-fly compilation of macro implementations, which compiles implementations into a virtual directory (very much like REPL does) and then conjures a classloader mapped to that virtual directory.

    Definition Classes
    MacroRuntimes
  57. def disambiguate(ss: List[String]): collection.immutable.List[String]

    Definition Classes
    TypeDiagnostics
  58. def enclosingMacroPosition: Position

    Definition Classes
    Macros
  59. def ensuring(cond: (Analyzer) ⇒ Boolean, msg: ⇒ Any): Analyzer

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

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

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

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

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

    Definition Classes
    AnyRef → Any
  65. def etaExpand(unit: Global.CompilationUnit, tree: Global.Tree, typer: Typer): Global.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
  66. object etaExpansion

    Definition Classes
    EtaExpansion
  67. def existentialContext(tp: Global.Type): String

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

    Definition Classes
    TypeDiagnostics
  69. def explainAnyVsAnyRef(found: Global.Type, req: Global.Type): String

    Definition Classes
    TypeDiagnostics
  70. def explainVariance(found: Global.Type, req: Global.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
  71. def extractorFormalTypes(pos: Global.Position, resTp: Global.Type, nbSubPats: Int, unappSym: Global.Symbol, effectiveNbSubPats: Int): (List[Global.Type], List[Global.Type])

    Returns (formals, formalsExpanded) where formalsExpanded are the expected types for the nbSubPats sub-patterns of an extractor pattern, of which the corresponding unapply[Seq] call is assumed to have result type resTp.

    Returns (formals, formalsExpanded) where formalsExpanded are the expected types for the nbSubPats sub-patterns of an extractor pattern, of which the corresponding unapply[Seq] call is assumed to have result type resTp.

    formals are the formal types before expanding a potential repeated parameter (must come last in formals, if at all)

    nbSubPats

    The number of arguments to the extractor pattern

    effectiveNbSubPats

    nbSubPats, unless there is one sub-pattern which, after unwrapping bind patterns, is a Tuple pattern, in which case it is the number of elements. Used to issue warnings about binding a TupleN to a single value.

    Definition Classes
    Infer
    Exceptions thrown
    TypeError

    when the unapply[Seq] definition is ill-typed

  72. def factoryMeth(mods: Global.Modifiers, name: Global.TermName, cdef: Global.ClassDef): Global.DefDef

    The apply method corresponding to a case class

    The apply method corresponding to a case class

    Definition Classes
    Unapplies
  73. final def falseIfNoInstance(body: ⇒ Boolean): Boolean

    Definition Classes
    Infer
    Annotations
    @inline()
  74. lazy val fastTrack: Map[Global.Symbol, FastTrackEntry]

    A map from a set of pre-established macro symbols to their implementations.

    A map from a set of pre-established macro symbols to their implementations.

    Definition Classes
    FastTrack
  75. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  76. def findMacroClassLoader(): ClassLoader

    Attributes
    protected
    Definition Classes
    Macros
  77. final def forArgMode(fun: Global.Tree, mode: Mode): reflect.internal.Mode

    Definition Classes
    Typers
  78. def formalTypes(formals: List[Global.Type], nargs: Int, removeByName: Boolean = true, removeRepeated: Boolean = true): List[Global.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
  79. def formatted(fmtstr: String): String

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

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

    A fresh type variable with given type parameter as origin.

    A fresh type variable with given type parameter as origin.

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

    Definition Classes
    AnyRef → Any
  83. def globalSettings: Settings

    Definition Classes
    MacrosTraces
  84. def hasMacroExpansionAttachment(any: Any): Boolean

    Determines whether the target is either an original or a result of a macro expansion.

    Determines whether the target is either an original or a result of a macro expansion. The parameter is of type Any, because macros can expand both into trees and into annotations.

    Definition Classes
    StdAttachments
  85. 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
  86. def hasSuperArgs(tree: Global.Tree): Boolean

    Determines whether the given tree has an associated SuperArgsAttachment.

    Determines whether the given tree has an associated SuperArgsAttachment.

    Definition Classes
    StdAttachments
  87. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  88. def increaseMetalevel(pre: Global.Type, tp: Global.Type): Global.Type

    Increases metalevel of the type, i.

    Increases metalevel of the type, i.e. transforms: * T to c.Expr[T]

    Definition Classes
    Helpers
    See also

    Metalevels.scala for more information and examples about metalevels

  89. def inferImplicit(tree: Global.Tree, pt: Global.Type, isView: Boolean, context: Context, silent: Boolean, withMacrosDisabled: Boolean, pos: Global.Position, onError: (Global.Position, String) ⇒ Unit): Global.Tree

    A friendly wrapper over inferImplicit to be used in macro contexts and toolboxes.

    A friendly wrapper over inferImplicit to be used in macro contexts and toolboxes.

    Definition Classes
    Implicits
  90. def inferImplicit(tree: Global.Tree, pt: Global.Type, reportAmbiguous: Boolean, isView: Boolean, context: Context, saveAmbiguousDivergent: Boolean, pos: Global.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
  91. def inferImplicit(tree: Global.Tree, pt: Global.Type, reportAmbiguous: Boolean, isView: Boolean, context: Context, saveAmbiguousDivergent: Boolean): SearchResult

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

    Definition Classes
    Implicits
  93. object instantiate extends Global.TypeMap

    Map every TypeVar to its constraint.

  94. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  95. def isMacroExpansionSuppressed(tree: Global.Tree): Boolean

    Determines whether a tree should not be expanded, because someone has put SuppressMacroExpansionAttachment on it or one of its children.

    Determines whether a tree should not be expanded, because someone has put SuppressMacroExpansionAttachment on it or one of its children.

    Definition Classes
    StdAttachments
  96. def isMacroImplRef(tree: Global.Tree): Boolean

    Determines whether a tree should or should not be adapted, because someone has put MacroImplRefAttachment on it.

    Determines whether a tree should or should not be adapted, because someone has put MacroImplRefAttachment on it.

    Definition Classes
    StdAttachments
  97. def isNamedArg(arg: Global.Tree): Boolean

    Definition Classes
    NamesDefaults
  98. var lastAccessCheckDetails: String

    Definition Classes
    Contexts
  99. var lastTreeToTyper: Global.Tree

    Definition Classes
    Typers
  100. def linePrecedes(t1: Global.Tree, t2: Global.Tree): Boolean

    Definition Classes
    TypeDiagnostics
  101. def linkExpandeeAndDesugared(expandee: Global.Tree, desugared: Global.Tree, role: MacroRole): Unit

    After macro expansion is completed, links the expandee and the expansion result by annotating them both with a MacroExpansionAttachment.

    After macro expansion is completed, links the expandee and the expansion result by annotating them both with a MacroExpansionAttachment.

    Definition Classes
    StdAttachments
  102. def linkExpandeeAndExpanded(expandee: Global.Tree, expanded: Any): Unit

    After macro expansion is completed, links the expandee and the expansion result by annotating them both with a MacroExpansionAttachment.

    After macro expansion is completed, links the expandee and the expansion result by annotating them both with a MacroExpansionAttachment. The expanded parameter is of type Any, because macros can expand both into trees and into annotations.

    Definition Classes
    StdAttachments
  103. def loadMacroImplBinding(macroDef: Global.Symbol): MacroImplBinding

    Definition Classes
    Macros
  104. def lockedCount: Int

    Definition Classes
    Namers
  105. def macroContext(typer: Typer, prefixTree: Global.Tree, expandeeTree: Global.Tree): MacroContext

    Definition Classes
    Macros
  106. val macroDebugLite: Boolean

    Definition Classes
    Traces
  107. val macroDebugVerbose: Boolean

    Definition Classes
    Traces
  108. def macroExpandAll(typer: Typer, expandee: Global.Tree): Global.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
  109. def macroExpandApply(typer: Typer, expandee: Global.Tree, mode: Mode, pt: Global.Type): Global.Tree

    Expands a term macro used in apply role as M(2)(3) in val x = M(2)(3).

    Expands a term macro used in apply role as M(2)(3) in val x = M(2)(3).

    Definition Classes
    Macros
    See also

    MacroExpander

  110. def macroExpandUnapply(typer: Typer, original: Global.Tree, fun: Global.Tree, unapply: Global.Symbol, args: List[Global.Tree], mode: Mode, pt: Global.Type): Global.Tree

    Expands a term macro used in unapply role as u.Quasiquote(StringContext("", "")).q.unapply(x) in case q"$x" => ....

    Expands a term macro used in unapply role as u.Quasiquote(StringContext("", "")).q.unapply(x) in case q"$x" => ....

    Definition Classes
    Macros
    See also

    MacroExpander

  111. def macroExpanderAttachment(tree: Global.Tree): MacroExpanderAttachment

    Loads underlying MacroExpanderAttachment from a macro expandee or returns a default value for that attachment.

    Loads underlying MacroExpanderAttachment from a macro expandee or returns a default value for that attachment.

    Definition Classes
    StdAttachments
  112. final def macroLogLite(msg: ⇒ Any): Unit

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

    Definition Classes
    Traces
    Annotations
    @inline()
  114. def macroRuntime(macroDef: Global.Symbol): (MacroArgs) ⇒ Any

    Definition Classes
    MacroRuntimes
  115. def makeNamedTypes(syms: List[Global.Symbol]): collection.immutable.List[Global.NamedType]

    Definition Classes
    NamesDefaults
  116. def markMacroImplRef(tree: Global.Tree): Global.Tree

    Marks the tree as a macro impl reference, which is a naked reference to a method.

    Marks the tree as a macro impl reference, which is a naked reference to a method.

    This is necessary for typechecking macro impl references (see DefaultMacroCompiler.defaultResolveMacroImpl), because otherwise typing a naked reference will result in the "follow this method with _' if you want to treat it as a partially applied function" errors.

    This mark suppresses adapt except for when the annottee is a macro application.

    Definition Classes
    StdAttachments
  117. def memberWildcardType(name: Global.Name, tp: Global.Type): Global.Type

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

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

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

    Definition Classes
    NamesDefaults
  119. def mkTypeCompleter(t: Global.Tree)(c: (Global.Symbol) ⇒ Unit): TypeCompleter with LockingTypeCompleter

    Definition Classes
    Namers
  120. object namerFactory extends SubComponent

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

    Definition Classes
    AnyRef
  122. def newNamer(context: Context): Namer

    Definition Classes
    Namers
  123. def newPatternMatching: Boolean

    Attributes
    protected
    Definition Classes
    Typers
  124. def newTyper(context: Context): Typer

    Definition Classes
    Typers
  125. def normalize(tp: Global.Type): Global.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
  126. def notAnyRefMessage(found: Global.Type): String

    Definition Classes
    ContextErrors
  127. final def notify(): Unit

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

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

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

    Definition Classes
    Macros
  131. def openMacros: collection.immutable.List[reflect.macros.contexts.Context { val universe: Analyzer.this.global.type }]

    Definition Classes
    Macros
  132. object packageObjects extends SubComponent

  133. def pluginsPt(pt: Global.Type, typer: Typer, tree: Global.Tree, mode: Mode): Global.Type

    Definition Classes
    AnalyzerPlugins
    See also

    AnalyzerPlugin.pluginsPt

  134. def pluginsTypeSig(tpe: Global.Type, typer: Typer, defTree: Global.Tree, pt: Global.Type): Global.Type

    Definition Classes
    AnalyzerPlugins
    See also

    AnalyzerPlugin.pluginsTypeSig

  135. def pluginsTypeSigAccessor(tpe: Global.Type, typer: Typer, tree: Global.ValDef, sym: Global.Symbol): Global.Type

    Definition Classes
    AnalyzerPlugins
    See also

    AnalyzerPlugin.pluginsTypeSigAccessor

  136. def pluginsTyped(tpe: Global.Type, typer: Typer, tree: Global.Tree, mode: Mode, pt: Global.Type): Global.Type

    Definition Classes
    AnalyzerPlugins
    See also

    AnalyzerPlugin.pluginsTyped

  137. def pluginsTypedReturn(tpe: Global.Type, typer: Typer, tree: Global.Return, pt: Global.Type): Global.Type

    Definition Classes
    AnalyzerPlugins
    See also

    AnalyzerPlugin.pluginsTypedReturn

  138. def posPrecedes(p1: Global.Position, p2: Global.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
  139. def propagateKnownTypes(from: Global.Type, to: Global.Symbol): Global.Type

    The applied type of class 'to' after inferring anything possible from the knowledge that 'to' must also be of the type given in 'from'.

    The applied type of class 'to' after inferring anything possible from the knowledge that 'to' must also be of the type given in 'from'.

    Definition Classes
    Checkable
  140. def removeNames(typer: Typer)(args: List[Global.Tree], params: List[Global.Symbol]): (List[Global.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
  141. def reorderArgs[T](args: List[T], pos: (Int) ⇒ Int)(implicit arg0: ClassTag[T]): List[T]

    pos

    maps indices from old to new

    Definition Classes
    NamesDefaults
  142. def resetContexts(): Unit

    Definition Classes
    Contexts
  143. def resetImplicits(): Unit

    Definition Classes
    Implicits
  144. def resetTyper(): Unit

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

    Definition Classes
    TypeDiagnostics
  146. def restrictionWarning(pos: Global.Position, unit: Global.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
  147. def rootContext(unit: Global.CompilationUnit, tree: Global.Tree = EmptyTree, erasedTypes: Boolean = false): Context

    Definition Classes
    Contexts
  148. def rootImports(unit: Global.CompilationUnit): List[Global.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
  149. def setAddendum(pos: Global.Position, msg: () ⇒ String): Unit

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

    Definition Classes
    Typers
  151. def skipImplicit(tp: Global.Type): Global.Type

    Definition Classes
    Infer
  152. def solvedTypes(tvars: List[Global.TypeVar], tparams: List[Global.Symbol], variances: List[Variance], upper: Boolean, depth: Int): List[Global.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

  153. def superArgs(tree: Global.Tree): Option[List[List[Global.Tree]]]

    Convenience method for SuperArgsAttachment.

    Convenience method for SuperArgsAttachment. Compared with MacroRuntimeAttachment this attachment has different a usage pattern, so it really benefits from a dedicated extractor.

    Definition Classes
    StdAttachments
  154. def suppressMacroExpansion(tree: Global.Tree): Global.Tree

    Suppresses macro expansion of the tree by putting SuppressMacroExpansionAttachment on it.

    Suppresses macro expansion of the tree by putting SuppressMacroExpansionAttachment on it.

    Definition Classes
    StdAttachments
  155. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  156. object synthesisUtil

    Definition Classes
    MethodSynthesis
  157. def toString(): String

    Definition Classes
    AnyRef → Any
  158. def transformNamedApplication(typer: Typer, mode: Mode, pt: Global.Type)(tree: Global.Tree, argPos: (Int) ⇒ Int): Global.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
  159. def transformTypeTagEvidenceParams(macroImplRef: Global.Tree, transform: (Global.Symbol, Global.Symbol) ⇒ Global.Symbol): List[List[Global.Symbol]]

    Transforms parameters lists of a macro impl.

    Transforms parameters lists of a macro impl. The transform function is invoked only for WeakTypeTag evidence parameters.

    The transformer takes two arguments: a value parameter from the parameter list and a type parameter that is witnesses by the value parameter.

    If the transformer returns a NoSymbol, the value parameter is not included from the result. If the transformer returns something else, this something else is included in the result instead of the value parameter.

    Despite of being highly esoteric, this function significantly simplifies signature analysis. For example, it can be used to strip macroImpl.paramss from the evidences (necessary when checking def <-> impl correspondence) or to streamline creation of the list of macro arguments.

    Definition Classes
    Helpers
  160. val transformed: HashMap[Global.Tree, Global.Tree]

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

    Definition Classes
    TypeDiagnostics
  162. def typePatternAdvice(sym: Global.Symbol, ptSym: Global.Symbol): String

    Definition Classes
    TypeDiagnostics
  163. def typedMacroBody(typer: Typer, macroDdef: Global.DefDef): Global.Tree

    Verifies that the body of a macro def typechecks to a reference to a static public non-overloaded method or a top-level macro bundle, and that that method is signature-wise compatible with the given macro definition.

    Verifies that the body of a macro def typechecks to a reference to a static public non-overloaded method or a top-level macro bundle, and that that method is signature-wise compatible with the given macro definition.

    returns

    Macro impl reference for the given macro definition if everything is okay. EmptyTree if an error occurs.

    Definition Classes
    Macros
  164. object typerFactory extends SubComponent

  165. def typingInPattern[T](body: ⇒ T): T

    Devising new ways of communicating error info out of desperation to work on error messages.

    Devising new ways of communicating error info out of desperation to work on error messages. This is used by typedPattern to wrap its business so we can generate a sensible error message when things go south.

    Definition Classes
    TypeDiagnostics
  166. def unapplyMember(tp: Global.Type): Global.Symbol

    returns unapply or unapplySeq if available

    returns unapply or unapplySeq if available

    Definition Classes
    Unapplies
  167. def unapplyParameterType(extractor: Global.Symbol): Global.Symbol

    returns unapply member's parameter type.

    returns unapply member's parameter type.

    Definition Classes
    Unapplies
  168. def unapplyTypeList(pos: Global.Position, ufn: Global.Symbol, ufntpe: Global.Type, args: List[Global.Tree]): List[Global.Type]

    returns type list for return type of the extraction

    returns type list for return type of the extraction

    Definition Classes
    Unapplies
    See also

    extractorFormalTypes

  169. def underlyingSymbol(member: Global.Symbol): Global.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
  170. def unmarkMacroImplRef(tree: Global.Tree): Global.Tree

    Unmarks the tree as a macro impl reference (see markMacroImplRef for more information).

    Unmarks the tree as a macro impl reference (see markMacroImplRef for more information).

    This is necessary when a tree that was previously deemed to be a macro impl reference, typechecks to be a macro application. Then we need to unmark it, expand it and try to treat its expansion as a macro impl reference.

    Definition Classes
    StdAttachments
  171. def unsuppressMacroExpansion(tree: Global.Tree): Global.Tree

    Unsuppresses macro expansion of the tree by removing SuppressMacroExpansionAttachment from it and its children.

    Unsuppresses macro expansion of the tree by removing SuppressMacroExpansionAttachment from it and its children.

    Definition Classes
    StdAttachments
  172. final def wait(): Unit

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

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

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  175. def warnUnusedImports(unit: Global.CompilationUnit): Unit

    Definition Classes
    Contexts
  176. def withAddendum(pos: Global.Position): (String) ⇒ String

    Definition Classes
    TypeDiagnostics
  177. def withDisambiguation[T](locals: List[Global.Symbol], types: Global.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
  178. def [B](y: B): (Analyzer, B)

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

Deprecated Value Members

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

    Definition Classes
    Namers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use companionSymbolOf instead

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

    Definition Classes
    Namers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use companionSymbolOf instead

  3. def underlying(member: Global.Symbol): Global.Symbol

    Definition Classes
    Namers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) Use underlyingSymbol instead

Inherited from AnalyzerPlugins

Inherited from StdAttachments

Inherited from ContextErrors

Inherited from TypeDiagnostics

Inherited from NamesDefaults

Inherited from Macros

Inherited from Helpers

Inherited from Traces

Inherited from MacroRuntimes

Inherited from ScalaReflectionRuntimes

Inherited from JavaReflectionRuntimes

Inherited from FastTrack

Inherited from Unapplies

Inherited from SyntheticMethods

Inherited from TreeDSL

Inherited from EtaExpansion

Inherited from Implicits

Inherited from Infer

Inherited from Checkable

Inherited from Typers

Inherited from Tags

Inherited from Adaptations

Inherited from Namers

Inherited from MethodSynthesis

Inherited from Contexts

Inherited from AnyRef

Inherited from Any

Inherited by implicit conversion StringAdd from Analyzer to StringAdd[Analyzer]

Inherited by implicit conversion StringFormat from Analyzer to StringFormat[Analyzer]

Inherited by implicit conversion Ensuring from Analyzer to Ensuring[Analyzer]

Inherited by implicit conversion ArrowAssoc from Analyzer to ArrowAssoc[Analyzer]

Ungrouped