trait ToolBox[U <: Universe] extends AnyRef
- Alphabetic
- By Inheritance
- ToolBox
- AnyRef
- Any
- by any2stringadd
- by StringFormat
- by Ensuring
- by ArrowAssoc
- Hide All
- Show All
- Public
- All
Type Members
-
abstract
type
TypecheckMode
Represents mode of operations of the typechecker underlying
c.typecheck
calls.Represents mode of operations of the typechecker underlying
c.typecheck
calls. Is necessary since the shape of the typechecked tree alone is not enough to guess how it should be typechecked. Can be EXPRmode (typecheck as a term), TYPEmode (typecheck as a type) or PATTERNmode (typecheck as a pattern).
Abstract Value Members
-
abstract
val
PATTERNmode: TypecheckMode
Indicates that an argument to
c.typecheck
should be typechecked as a pattern. -
abstract
val
TERMmode: TypecheckMode
Indicates that an argument to
c.typecheck
should be typechecked as a term.Indicates that an argument to
c.typecheck
should be typechecked as a term. This is the default typechecking mode in Scala 2.11 and the only one supported in Scala 2.10. -
abstract
val
TYPEmode: TypecheckMode
Indicates that an argument to
c.typecheck
should be typechecked as a type. -
abstract
def
compile(tree: U.Tree): () ⇒ Any
Compiles a tree using this ToolBox.
Compiles a tree using this ToolBox.
If the tree has unresolved type variables (represented as instances of
FreeTypeSymbol
symbols), then they all have to be resolved first usingTree.substituteTypes
, or an error occurs.This spawns the compiler at the Namer phase, and pipelines the tree through that compiler. Currently
compile
does not accept trees that already typechecked, because typechecking isn't idempotent. For more info, take a look at https://issues.scala-lang.org/browse/SI-5464. -
abstract
def
define(tree: U.ImplDef): U.Symbol
Defines a top-level class, trait or module in this ToolBox, putting it into a uniquely-named package and returning a symbol that references the defined entity.
Defines a top-level class, trait or module in this ToolBox, putting it into a uniquely-named package and returning a symbol that references the defined entity. For a ClassDef, a ClassSymbol is returned, and for a ModuleDef, a ModuleSymbol is returned (not a module class, but a module itself).
This method can be used to generate definitions that will later be re-used by subsequent calls to
compile
,define
oreval
. To refer to the generated definition in a tree, use q"$sym". -
abstract
def
eval(tree: U.Tree): Any
Compiles and runs a tree using this ToolBox.
Compiles and runs a tree using this ToolBox. Is equivalent to
compile(tree)()
. -
abstract
def
frontEnd: FrontEnd
Front end of the toolbox.
Front end of the toolbox.
Accumulates and displays warnings and errors, can drop to interactive mode (if supported). The latter can be useful to study the typechecker or to debug complex macros.
scala.tools.reflect provides two predefined front ends that can be created using scala.tools.reflect.mkSilentFrontEnd and scala.tools.reflect.mkConsoleFrontEnd.
-
abstract
def
inferImplicitValue(pt: U.Type, silent: Boolean = true, withMacrosDisabled: Boolean = false, pos: U.Position = u.NoPosition): U.Tree
Infers an implicit value of the expected type
pt
in top-level context.Infers an implicit value of the expected type
pt
in top-level context. Optionalpos
parameter provides a position that will be associated with the implicit search.As mentioned in https://groups.google.com/forum/#!topic/scala-internals/ta-vbUT6JE8 this API won't take into account the lexical context of the callsite, because currently it's impossible to reify it.
If
silent
is false,ToolBoxError
will be thrown in case of an inference error. Ifsilent
is true, the typecheck is silent and will returnEmptyTree
if an error occurs. Such errors don't vanish and can be inspected by turning on -Xlog-implicits. Unlike intypecheck
,silent
is true by default. -
abstract
def
inferImplicitView(tree: U.Tree, from: U.Type, to: U.Type, silent: Boolean = true, withMacrosDisabled: Boolean = false, pos: U.Position = u.NoPosition): U.Tree
Infers an implicit view from the provided tree
tree
from the typefrom
to the typeto
in the toplevel context.Infers an implicit view from the provided tree
tree
from the typefrom
to the typeto
in the toplevel context. Optionalpos
parameter provides a position that will be associated with the implicit search.As mentioned in https://groups.google.com/forum/#!topic/scala-internals/ta-vbUT6JE8 this API won't take into account the lexical context of the callsite, because currently it's impossible to reify it.
If
silent
is false,ToolBoxError
will be thrown in case of an inference error. Ifsilent
is true, the typecheck is silent and will returnEmptyTree
if an error occurs. Such errors don't vanish and can be inspected by turning on -Xlog-implicits. Unlike intypecheck
,silent
is true by default. -
abstract
val
mirror: U.Mirror
Underlying mirror of a ToolBox
-
abstract
def
parse(code: String): U.Tree
..
-
abstract
def
typecheck(tree: U.Tree, mode: TypecheckMode = TERMmode, pt: U.Type = u.WildcardType, silent: Boolean = false, withImplicitViewsDisabled: Boolean = false, withMacrosDisabled: Boolean = false): U.Tree
Typechecks a tree against the expected type
pt
under typechecking mode specified inmode
with EXPRmode being default.Typechecks a tree against the expected type
pt
under typechecking mode specified inmode
with EXPRmode being default. This populates symbols and types of the tree and possibly transforms it to reflect certain desugarings.If the tree has unresolved type variables (represented as instances of
FreeTypeSymbol
symbols), then they all have to be resolved first usingTree.substituteTypes
, or an error occurs.If
silent
is false,ToolBoxError
will be thrown in case of a typecheck error. Ifsilent
is true, the typecheck is silent and will returnEmptyTree
if an error occurs. Such errors don't vanish and can be inspected by turning on -Ydebug.Typechecking can be steered with the following optional parameters:
withImplicitViewsDisabled
recursively prohibits implicit views (though, implicit vals will still be looked up and filled in), default value is falsewithMacrosDisabled
recursively prohibits macro expansions and macro-based implicits, default value is false -
abstract
val
u: U
Underlying universe of a ToolBox
-
abstract
def
untypecheck(tree: U.Tree): U.Tree
- See also
scala.reflect.macros.Typers.untypecheck
-
abstract
def
resetLocalAttrs(tree: U.Tree): U.Tree
Recursively resets locally defined symbols and types in a given tree.
Recursively resets locally defined symbols and types in a given tree. WARNING: Don't use this API, go for untypecheck instead.
- Annotations
- @deprecated
- Deprecated
(Since version 2.11.0) Use
tb.untypecheck
instead
Concrete Value Members
-
final
def
!=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
##(): Int
- Definition Classes
- AnyRef → Any
- def +(other: String): String
- def ->[B](y: B): (ToolBox[U], B)
-
final
def
==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
asInstanceOf[T0]: T0
- Definition Classes
- Any
-
def
clone(): AnyRef
- Attributes
- protected[java.lang]
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
- def ensuring(cond: (ToolBox[U]) ⇒ Boolean, msg: ⇒ Any): ToolBox[U]
- def ensuring(cond: (ToolBox[U]) ⇒ Boolean): ToolBox[U]
- def ensuring(cond: Boolean, msg: ⇒ Any): ToolBox[U]
- def ensuring(cond: Boolean): ToolBox[U]
-
final
def
eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
def
equals(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
def
finalize(): Unit
- Attributes
- protected[java.lang]
- Definition Classes
- AnyRef
- Annotations
- @throws( classOf[java.lang.Throwable] )
- def formatted(fmtstr: String): String
-
final
def
getClass(): Class[_]
- Definition Classes
- AnyRef → Any
-
def
hashCode(): Int
- Definition Classes
- AnyRef → Any
-
final
def
isInstanceOf[T0]: Boolean
- Definition Classes
- Any
-
final
def
ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
final
def
notify(): Unit
- Definition Classes
- AnyRef
-
final
def
notifyAll(): Unit
- Definition Classes
- AnyRef
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
- Definition Classes
- AnyRef
-
def
toString(): String
- Definition Classes
- AnyRef → Any
-
final
def
wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
- def →[B](y: B): (ToolBox[U], B)
Deprecated Value Members
-
def
typeCheck(tree: U.Tree, pt: U.Type = u.WildcardType, silent: Boolean = false, withImplicitViewsDisabled: Boolean = false, withMacrosDisabled: Boolean = false): U.Tree
- Annotations
- @deprecated
- Deprecated
(Since version 2.11.0) Use
tb.typecheck
instead- See also
Typers.typecheck
The Scala compiler API.
The following resources are useful for Scala plugin/compiler development: