scala.tools.nsc.typechecker.Contexts

Context

class Context extends AnyRef

A motley collection of the state and loosely associated behaviour of the type checker. Each Typer has an associated context, and as it descends into the tree new (Typer, Context) pairs are spawned.

Meet the crew; first the state:

And behaviour:

More on error buffering: When are type errors recoverable? In quite a few places, it turns out. Some examples: trying to type an application with/without the expected type, or with/without implicit views enabled. This is usually mediated by Typer.silent, Inferencer#tryTwice.

Intially, starting from the typer phase, the contexts either buffer or report errors; afterwards errors are thrown. This is configured in rootContext. Additionally, more fine grained control is needed based on the kind of error; ambiguity errors are often suppressed during exploraratory typing, such as determining whether a == b in an argument position is an assignment or a named argument, when Infererencer#isApplicableSafe type checks applications with and without an expected type, or whtn Typer#tryTypedApply tries to fit arguments to a function type with/without implicit views.

When the error policies entails error/warning buffering, the mutable ReportBuffer records everything that is issued. It is important to note, that child Contexts created with make "inherit" the very same ReportBuffer instance, whereas children spawned through makeSilent receive an separate, fresh buffer.

Linear Supertypes
AnyRef, Any
Known Subclasses
Type Hierarchy Learn more about scaladoc diagrams
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. Context
  2. AnyRef
  3. 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

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

    Implicit information
    This member is added by an implicit conversion from Analyzer.Context to ArrowAssoc[Analyzer.Context] 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. def ambiguousErrors: Boolean

  9. def apply(mask: ContextMode): Boolean

    Is this context in all modes in the given mask?

  10. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  11. def bufferErrors: Boolean

  12. def checking: Boolean

  13. def checking_=(value: Boolean): Unit

  14. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  15. var contextMode: ContextMode

    A bitmask containing all the boolean flags in a context, e.

    A bitmask containing all the boolean flags in a context, e.g. are implicit views enabled

  16. val depth: Int

  17. var diagnostic: List[String]

    These messages are printed when issuing an error

  18. var enclClass: Analyzer.Context

    The next outer context whose tree is a template or package definition

  19. def enclClassOrMethod: Analyzer.Context

    The next enclosing context (potentially this) that is owned by a class or method

  20. var enclMethod: Analyzer.Context

    The next outer context whose tree is a method

  21. def enclosingApply: Analyzer.Context

    .

    ...or an Apply.

  22. def enclosingCaseDef: Analyzer.Context

    The next enclosing context (potentially this) that has a CaseDef as a tree

  23. def enclosingContextChain: List[Analyzer.Context]

  24. def enclosingSubClassContext(clazz: Global.Symbol): Analyzer.Context

    Return the closest enclosing context that defines a subclass of clazz or a companion object thereof, or NoContext if no such context exists.

  25. def enrichmentEnabled: Boolean

  26. def enrichmentEnabled_=(value: Boolean): Unit

  27. def ensuring(cond: (Analyzer.Context) ⇒ Boolean, msg: ⇒ Any): Analyzer.Context

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

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

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

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

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

    Definition Classes
    AnyRef → Any
  33. def error(pos: Global.Position, msg: String): Unit

    Issue/throw the given error message according to the current mode for error reporting.

  34. def error(pos: Global.Position, err: Throwable): Unit

    Issue/throw the given err according to the current mode for error reporting.

  35. def extractUndetparams(): List[Global.Symbol]

    Return and clear the undetermined type parameters

  36. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  37. def firstError: Option[Analyzer.AbsTypeError]

    The first error, if any, in the report buffer

  38. def firstImport: Option[Analyzer.ImportInfo]

    Equivalent to imports.headOption, but more efficient

  39. def flushAndIssueWarnings(): Unit

    Issue and clear all warnings from the report buffer

  40. def flushAndReturnBuffer(): collection.immutable.Seq[Analyzer.AbsTypeError]

    Return and clear all errors from the report buffer

  41. def flushBuffer(): Unit

    Clear all errors from the report buffer

  42. def formatted(fmtstr: String): String

    Implicit information
    This member is added by an implicit conversion from Analyzer.Context to StringFormat[Analyzer.Context] performed by method StringFormat in scala.Predef.
    Definition Classes
    StringFormat
    Annotations
    @inline()
  43. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  44. def hasErrors: Boolean

    Does the report buffer contain any errors?

  45. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  46. def implicitsEnabled: Boolean

  47. def implicitsEnabled_=(value: Boolean): Unit

  48. def implicitss: List[List[Analyzer.ImplicitInfo]]

  49. def importedAccessibleSymbol(imp: Analyzer.ImportInfo, name: Global.Name): Global.Symbol

    The symbol with name name imported via the import in imp, if any such symbol is accessible from this context.

  50. def imports: List[Analyzer.ImportInfo]

    The currently visible imports

  51. def inConstructorSuffix: Boolean

  52. def inConstructorSuffix_=(value: Boolean): Unit

  53. def inSelfSuperCall: Boolean

  54. def inSelfSuperCall_=(value: Boolean): Unit

  55. final def inSilentMode(expr: ⇒ Boolean): Boolean

    returns

    true if the expr evaluates to true within a silent Context that incurs no errors

    Annotations
    @inline()
  56. def isAccessible(sym: Global.Symbol, pre: Global.Type, superAccess: Boolean = false): Boolean

    Is sym accessible as a member of pre in current context?

  57. def isInPackageObject(sym: Global.Symbol, pkg: Global.Symbol): Boolean

    Is sym defined in package object of package pkg? Since sym may be defined in some parent of the package object, we cannot inspect its owner only; we have to go through the info of the package object.

    Is sym defined in package object of package pkg? Since sym may be defined in some parent of the package object, we cannot inspect its owner only; we have to go through the info of the package object. However to avoid cycles we'll check what other ways we can before pushing that way.

  58. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  59. final def isLocal: Boolean

    Is the owning symbol of this context a term?

  60. def isNameInScope(name: Global.Name): Boolean

  61. def isRootImport: Boolean

  62. def issue(err: Analyzer.AbsTypeError): Unit

    Issue/buffer/throw the given type error according to the current mode for error reporting.

  63. def issueAmbiguousError(err: Analyzer.AbsTypeError): Unit

    Issue/buffer/throw the given implicit ambiguity error according to the current mode for error reporting.

  64. def issueAmbiguousError(pre: Global.Type, sym1: Global.Symbol, sym2: Global.Symbol, err: Analyzer.AbsTypeError): Unit

    Issue/buffer/throw the given implicit ambiguity error according to the current mode for error reporting.

  65. def lookup(name: Global.Name, expectedOwner: Global.Symbol): Global.Symbol

    Find a symbol in this context or one of its outers.

    Find a symbol in this context or one of its outers.

    Used to find symbols are owned by methods (or fields), they can't be found in some scope.

    Examples: companion module of classes owned by a method, default getter methods of nested methods. See NamesDefaults.scala

  66. def lookupSymbol(name: Global.Name, qualifies: (Global.Symbol) ⇒ Boolean): Global.NameLookup

    Find the symbol of a simple name starting from this context.

    Find the symbol of a simple name starting from this context. All names are filtered through the "qualifies" predicate, the search continuing as long as no qualifying name is found.

  67. def macrosEnabled: Boolean

  68. def macrosEnabled_=(value: Boolean): Unit

  69. def make(tree: Global.Tree, owner: Global.Symbol, scope: Global.Scope): Analyzer.Context

  70. def make(tree: Global.Tree = tree, owner: Global.Symbol = owner, scope: Global.Scope = scope, unit: Global.CompilationUnit = unit): Analyzer.Context

    Construct a child context.

    Construct a child context. The parent and child will share the report buffer. Compare with makeSilent, in which the child has a fresh report buffer.

    If tree is an Import, that import will be avaiable at the head of Context#imports.

  71. def makeConstructorContext: Analyzer.Context

    A context for typing constructor parameter ValDefs, super or self invocation arguments and default getters of constructors.

    A context for typing constructor parameter ValDefs, super or self invocation arguments and default getters of constructors. These expressions need to be type checked in a scope outside the class, cf. spec 5.3.1.

    This method is called by namer / typer where this is the context for the constructor DefDef. The owner of the resulting (new) context is the outer context for the Template, i.e. the context for the ClassDef. This means that class type parameters will be in scope. The value parameters of the current constructor are also entered into the new constructor scope. Members of the class however will not be accessible.

  72. def makeImplicit(reportAmbiguousErrors: Boolean): Analyzer.Context

    Make a silent child context does not allow implicits.

    Make a silent child context does not allow implicits. Used to prevent chaining of implicit views.

  73. def makeNewScope(tree: Global.Tree, owner: Global.Symbol): Analyzer.Context

    Make a child context that represents a new nested scope

  74. def makeSilent(reportAmbiguousErrors: Boolean = ambiguousErrors, newtree: Global.Tree = tree): Analyzer.Context

    Make a child context that buffers errors and warnings into a fresh report buffer.

  75. var namedApplyBlockInfo: Option[(Global.Tree, Analyzer.NamedApplyInfo)]

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

    Definition Classes
    AnyRef
  77. def nextEnclosing(p: (Analyzer.Context) ⇒ Boolean): Analyzer.Context

  78. final def notify(): Unit

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

    Definition Classes
    AnyRef
  80. var openImplicits: List[Analyzer.OpenImplicit]

    Types for which implicit arguments are currently searched

  81. final def outer: Analyzer.Context

  82. def outerDepth: Int

    Attributes
    protected
  83. val owner: Global.Symbol

    The current owner

  84. var prefix: Global.Type

  85. def pushTypeBounds(sym: Global.Symbol): Unit

  86. def reportBuffer: Analyzer.ReportBuffer

    A buffer for errors and warnings, used with this.bufferErrors == true

  87. def reportErrors: Boolean

  88. def resetCache(): Unit

  89. def restoreReportBuffer(other: Analyzer.ReportBuffer): Unit

    Discard the current report buffer, and replace with other

  90. def restoreTypeBounds(tp: Global.Type): Global.Type

  91. def returnsSeen: Boolean

  92. def returnsSeen_=(value: Boolean): Unit

  93. def retyping: Boolean

  94. def retyping_=(value: Boolean): Unit

  95. var savedTypeBounds: List[(Global.Symbol, Global.Type)]

    Saved type bounds for type parameters which are narrowed in a GADT.

  96. def savingUndeterminedTypeParams[A](reportAmbiguous: Boolean = ambiguousErrors)(body: ⇒ A): A

    Run body with this context with no undetermined type parameters, restore the original the original list afterwards.

    Run body with this context with no undetermined type parameters, restore the original the original list afterwards.

    reportAmbiguous

    Should ambiguous errors be reported during evaluation of body?

  97. val scope: Global.Scope

    The current scope

  98. def set(enable: ContextMode = NOmode, disable: ContextMode = NOmode): Context.this.type

    Set all modes in the mask enable to true, and all in disable to false.

  99. def setAmbiguousErrors(report: Boolean): Unit

  100. def setBufferErrors(): Unit

  101. def setReportErrors(): Unit

  102. def setThrowErrors(): Unit

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

    Definition Classes
    AnyRef
  104. def throwErrors: Boolean

  105. def toString(): String

    Definition Classes
    Context → AnyRef → Any
  106. val tree: Global.Tree

    Tree associated with this context

  107. def typingIndent: String

  108. var typingIndentLevel: Int

    Indentation level, in columns, for output under -Ytyper-debug

  109. def undetparams: List[Global.Symbol]

    Undetermined type parameters.

    Undetermined type parameters. See Infer#{inferExprInstance, adjustTypeArgs}. Not inherited to child contexts

  110. def undetparamsString: String

  111. def undetparams_=(ps: List[Global.Symbol]): Unit

  112. val unit: Global.CompilationUnit

  113. def update(mask: ContextMode, value: Boolean): Unit

    Update all modes in mask to value

  114. def updateBuffer(errors: Traversable[Analyzer.AbsTypeError]): Analyzer.ReportBuffer

    Append the given errors to the report buffer

  115. def useFreshReportBuffer(): Unit

    Discard the current report buffer, and replace with an empty one

  116. var variance: Variance

    Variance relative to enclosing class

  117. final def wait(): Unit

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

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

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  120. def warning(pos: Global.Position, msg: String, force: Boolean = false): Unit

    Issue/throw the given error message according to the current mode for error reporting.

  121. def withImplicitsDisabled[T](op: ⇒ T): T

  122. def withImplicitsDisabledAllowEnrichment[T](op: ⇒ T): T

  123. def withImplicitsEnabled[T](op: ⇒ T): T

  124. def withMacrosDisabled[T](op: ⇒ T): T

  125. def withMacrosEnabled[T](op: ⇒ T): T

  126. def withMode[T](enabled: ContextMode = NOmode, disabled: ContextMode = NOmode)(op: ⇒ T): T

    Annotations
    @inline()
  127. def [B](y: B): (Analyzer.Context, B)

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

Inherited from AnyRef

Inherited from Any

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

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

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

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

Ungrouped