ApplyToTyped

dotty.tools.dotc.typer.Applications.ApplyToTyped
class ApplyToTyped(app: Apply, fun: Tree, methRef: TermRef, args: List[Tree], resultType: Type, applyKind: ApplyKind)(using x$7: Context) extends TypedApply[Type]

Subclass of Application for type checking an Apply node with typed arguments.

Attributes

Graph
Supertypes
class TypedApply[Type]
class Object
trait Matchable
class Any

Members list

Type members

Inherited types

type TypedArg = Tree

The type of typed arguments: either tpd.Tree or Type

The type of typed arguments: either tpd.Tree or Type

Attributes

Inherited from:
TypedApply

Value members

Concrete methods

def treeToArg(arg: Tree): Tree

Turn a typed tree into an argument

Turn a typed tree into an argument

Attributes

def typeOfArg(arg: Tree): Type
def typedArg(arg: Tree, formal: Type): TypedArg

Given an original argument and the type of the corresponding formal parameter, produce a typed argument.

Given an original argument and the type of the corresponding formal parameter, produce a typed argument.

Attributes

Inherited methods

def addArg(arg: Tree, formal: Type): Unit

Check that argument corresponds to type formal and possibly add it to the list of adapted arguments

Check that argument corresponds to type formal and possibly add it to the list of adapted arguments

Attributes

Inherited from:
TypedApply
override def appPos: SrcPos

Attributes

Definition Classes
Inherited from:
TypedApply
def fail(msg: Message): Unit

Signal failure with given message at position of the application itself

Signal failure with given message at position of the application itself

Attributes

Inherited from:
TypedApply
def fail(msg: Message, arg: Tree[Type]): Unit

Signal failure with given message at position of given argument

Signal failure with given message at position of given argument

Attributes

Inherited from:
TypedApply

If all args have primitive numeric types, make sure it's the same one

If all args have primitive numeric types, make sure it's the same one

Attributes

Inherited from:
TypedApply
protected def init(): Unit

Attributes

Inherited from:
Application

Is sym a constructor of a Java-defined annotation?

Is sym a constructor of a Java-defined annotation?

Attributes

Inherited from:
Application
def isSafeArg(arg: Tree): Boolean

An argument is safe if it is a pure expression or a default getter call If all arguments are safe, no reordering is necessary

An argument is safe if it is a pure expression or a default getter call If all arguments are safe, no reordering is necessary

Attributes

Inherited from:
TypedApply
def isVarArg(arg: Tree[Type]): Boolean

Is this an argument of the form expr: _* or a RepeatedParamType derived from such an argument?

Is this an argument of the form expr: _* or a RepeatedParamType derived from such an argument?

Attributes

Inherited from:
TypedApply
override def liftFun(): Unit

If constructing trees, pull out all parts of the function which are not idempotent into separate prefix definitions

If constructing trees, pull out all parts of the function which are not idempotent into separate prefix definitions

Attributes

Definition Classes
Inherited from:
TypedApply
def makeVarArg(n: Int, elemFormal: Type): Unit

If constructing trees, turn last n processed arguments into a SeqLiteral tree with element type elemFormal.

If constructing trees, turn last n processed arguments into a SeqLiteral tree with element type elemFormal.

Attributes

Inherited from:
TypedApply
def matchArgs(args: List[Tree[Type]], formals: List[Type], n: Int): Unit

Match re-ordered arguments against formal parameters

Match re-ordered arguments against formal parameters

Value parameters

n

The position of the first parameter in formals in methType.

Attributes

Inherited from:
Application
protected def methodType: MethodType

Attributes

Inherited from:
Application
protected def needLiftFun: Boolean

Whether liftFun is needed? It is the case if default arguments are used.

Whether liftFun is needed? It is the case if default arguments are used.

Attributes

Inherited from:
Application

The current function part, which might be affected by lifting.

The current function part, which might be affected by lifting.

Attributes

Inherited from:
TypedApply
def ok: Boolean

Attributes

Inherited from:
Application
def ok_=(x: Boolean): Unit

Attributes

Inherited from:
Application
def reorder[T <: Untyped](args: List[Tree[T]]): List[Tree[T]]

Re-order arguments to correctly align named arguments

Re-order arguments to correctly align named arguments

Attributes

Inherited from:
Application

The application was successful

The application was successful

Attributes

Inherited from:
Application

Inherited fields

lazy val liftedFunType: Type

Attributes

Inherited from:
Application
lazy val methType: Type

The function's type after widening and instantiating polytypes with TypeParamRefs in constraint set

The function's type after widening and instantiating polytypes with TypeParamRefs in constraint set

Attributes

Inherited from:
Application
lazy val orderedArgs: List[Tree[Type]]

The arguments re-ordered so that each named argument matches the same-named formal parameter.

The arguments re-ordered so that each named argument matches the same-named formal parameter.

Attributes

Inherited from:
Application
val result: Tree

Attributes

Inherited from:
TypedApply