- Definition Classes
ClassDenotation
The contents of a class definition during a period
Type members
Inherited types
Value members
Concrete methods
The base classes of this class in linearization order, with the class itself as first element.
The base classes of this class in linearization order, with the class itself as first element.
Delete symbol from current scope. Note: We require that this does not happen after the first time someone does a findMember on a subclass.
Delete symbol from current scope. Note: We require that this does not happen after the first time someone does a findMember on a subclass.
If this class has the same decls
scope reference in phase
and
phase.next
, install a new denotation with a cloned scope in phase.next
.
If this class has the same decls
scope reference in phase
and
phase.next
, install a new denotation with a cloned scope in phase.next
.
Make sure the type parameters of this class appear in the order given
by typeParams
in the scope of the class. Reorder definitions in scope if necessary.
Make sure the type parameters of this class appear in the order given
by typeParams
in the scope of the class. Reorder definitions in scope if necessary.
Enter a symbol in current scope, and future scopes of same denotation. Note: We require that this does not happen after the first time someone does a findMember on a subclass.
Enter a symbol in current scope, and future scopes of same denotation. Note: We require that this does not happen after the first time someone does a findMember on a subclass.
- Value parameters:
- scope
The scope in which symbol should be entered. If this is EmptyScope, the scope is
decls
.
Enter a symbol in given scope
without potentially replacing the old copy.
Enter a symbol in given scope
without potentially replacing the old copy.
- Definition Classes
The explicitly given self type (self types of modules are assumed to be explcitly given here).
The explicitly given self type (self types of modules are assumed to be explcitly given here).
Is it possible that a class inherits both this
and that
?
Is it possible that a class inherits both this
and that
?
- Returns:
The result may contain false positives, but never false negatives.
- Note:
The test is based on single-class inheritance and the closed hierarchy of final classes.
All members of this class that have the given name. The elements of the returned pre-denotation all have existing symbols.
All members of this class that have the given name. The elements of the returned pre-denotation all have existing symbols.
All members of this class that have the given name and match the
required
and excluded
flag sets; members excluded based on the
flag sets do not shadow inherited members that would not be excluded.
All members of this class that have the given name and match the
required
and excluded
flag sets; members excluded based on the
flag sets do not shadow inherited members that would not be excluded.
The elements of the returned pre-denotation all have existing symbols.
All non-private members of this class that have the given name. The elements of the returned pre-denotation all have existing symbols.
All non-private members of this class that have the given name. The elements of the returned pre-denotation all have existing symbols.
The term parameter accessors of this class. Both getters and setters are returned in this list.
The term parameter accessors of this class. Both getters and setters are returned in this list.
Replace symbol prev
(if defined in current class) by symbol replacement
.
If prev
is not defined in current class, do nothing.
Replace symbol prev
(if defined in current class) by symbol replacement
.
If prev
is not defined in current class, do nothing.
The symbol of the superclass, NoSymbol if no superclass exists
The symbol of the superclass, NoSymbol if no superclass exists
The this-type depends on the kind of class:
The this-type depends on the kind of class:
- for a package class
p
: ThisType(TypeRef(Noprefix, p)) - for a module class
m
: A term ref to m's source module. - for all other classes
c
with ownero
: ThisType(TypeRef(o.thisType, c))
- Definition Classes
Inherited methods
The class or term symbol up to which this symbol is accessible, or RootClass if it is public. As java protected statics are otherwise completely inaccessible in scala, they are treated as public.
The class or term symbol up to which this symbol is accessible, or RootClass if it is public. As java protected statics are otherwise completely inaccessible in scala, they are treated as public.
- Value parameters:
- base
The access boundary to assume if this symbol is protected
- Inherited from:
- SymDenotation
The field accessed by this getter or setter, or if it does not exist, the getter
The field accessed by this getter or setter, or if it does not exist, the getter
- Inherited from:
- SymDenotation
Add the given annotation without parameters to the annotations of this denotation
Add the given annotation without parameters to the annotations of this denotation
- Inherited from:
- SymDenotation
Add given annotation to the annotations of this denotation
Add given annotation to the annotations of this denotation
- Inherited from:
- SymDenotation
Add all given annotations to this symbol
Add all given annotations to this symbol
- Inherited from:
- SymDenotation
All symbols overridden by this denotation.
All symbols overridden by this denotation.
- Inherited from:
- SymDenotation
The set of alternative single-denotations making up this denotation
The set of alternative single-denotations making up this denotation
- Inherited from:
- Denotation
Update the annotations of this denotation
Update the annotations of this denotation
- Inherited from:
- SymDenotation
The denotation with info(s) as seen from prefix type
The denotation with info(s) as seen from prefix type
- Inherited from:
- PreDenotation
- Inherited from:
- SingleDenotation
If false, this symbol cannot possibly participate in an override, either as overrider or overridee.
If false, this symbol cannot possibly participate in an override, either as overrider or overridee.
- Inherited from:
- SymDenotation
If this is a SingleDenotation, return it, otherwise throw a TypeError
If this is a SingleDenotation, return it, otherwise throw a TypeError
- Inherited from:
- Denotation
If this is a sealed class, its known children in the order of textual occurrence
If this is a sealed class, its known children in the order of textual occurrence
- Inherited from:
- SymDenotation
The class with the same (type-) name as this module or module class, and which is also defined in the same scope and compilation unit. NoSymbol if this class does not exist.
The class with the same (type-) name as this module or module class, and which is also defined in the same scope and compilation unit. NoSymbol if this class does not exist.
- Inherited from:
- SymDenotation
The module object with the same (term-) name as this class or module class, and which is also defined in the same scope and compilation unit. NoSymbol if this module does not exist.
The module object with the same (term-) name as this class or module class, and which is also defined in the same scope and compilation unit. NoSymbol if this module does not exist.
- Inherited from:
- SymDenotation
If this denotation is not completed, run the completer. The resulting info might be another completer.
If this denotation is not completed, run the completer. The resulting info might be another completer.
- See also:
ensureCompleted
- Inherited from:
- SymDenotation
The completer of this denotation. @pre: Denotation is not yet completed
The completer of this denotation. @pre: Denotation is not yet completed
- Inherited from:
- SymDenotation
Is this symbol a module that contains opaque aliases?
Is this symbol a module that contains opaque aliases?
- Inherited from:
- SymDenotation
Copy this denotation, overriding selective fields
Copy this denotation, overriding selective fields
- Inherited from:
- SymDenotation
The period (interval of phases) for which there exists a valid denotation in this flock.
The period (interval of phases) for which there exists a valid denotation in this flock.
- Inherited from:
- SingleDenotation
Produce a denotation that is valid for the given context. Usually called when !(validFor contains ctx.period) (even though this is not a precondition). If the runId of the context is the same as runId of this denotation, the right flock member is located, or, if it does not exist yet, created by invoking a transformer (@See Transformers). If the runId's differ, but this denotation is a SymDenotation and its toplevel owner class or module is still a member of its enclosing package, then the whole flock is brought forward to be valid in the new runId. Otherwise the symbol is stale, which constitutes an internal error.
Produce a denotation that is valid for the given context. Usually called when !(validFor contains ctx.period) (even though this is not a precondition). If the runId of the context is the same as runId of this denotation, the right flock member is located, or, if it does not exist yet, created by invoking a transformer (@See Transformers). If the runId's differ, but this denotation is a SymDenotation and its toplevel owner class or module is still a member of its enclosing package, then the whole flock is brought forward to be valid in the new runId. Otherwise the symbol is stale, which constitutes an internal error.
- Inherited from:
- SingleDenotation
The current declaration in this symbol's class owner that has the same name as this one, and, if there are several, also has the same signature.
The current declaration in this symbol's class owner that has the same name as this one, and, if there are several, also has the same signature.
- Inherited from:
- SymDenotation
- Inherited from:
- SingleDenotation
If this denotation is overloaded, filter with given predicate. If result is still overloaded throw a TypeError. Note: disambiguate is slightly different from suchThat in that single-denotations that do not satisfy the predicate are left alone (whereas suchThat would map them to NoDenotation).
If this denotation is overloaded, filter with given predicate. If result is still overloaded throw a TypeError. Note: disambiguate is slightly different from suchThat in that single-denotations that do not satisfy the predicate are left alone (whereas suchThat would map them to NoDenotation).
- Inherited from:
- Denotation
The name, except
The name, except
- if this is a module class, strip the module class suffix
- if this is a companion object with a clash-avoiding name, strip the "avoid clash" suffix
- Inherited from:
- SymDenotation
The owner, skipping package objects and non-lazy valdefs.
The owner, skipping package objects and non-lazy valdefs.
- Inherited from:
- SymDenotation
The class containing this denotation.
If this denotation is already a class, return itself
Definitions flagged with JavaStatic are treated specially.
Their enclosing class is not the lexically enclosing class,
but in turn the enclosing class of the latter. This reflects
the context created by Context#superCallContext
, Context#thisCallArgContext
for these definitions.
The class containing this denotation.
If this denotation is already a class, return itself
Definitions flagged with JavaStatic are treated specially.
Their enclosing class is not the lexically enclosing class,
but in turn the enclosing class of the latter. This reflects
the context created by Context#superCallContext
, Context#thisCallArgContext
for these definitions.
Note, that as packages have ClassSymbols, top level classes will have an enclosingClass
with Package flag set.
- Inherited from:
- SymDenotation
The class containing this denotation which has the given effective name.
The class containing this denotation which has the given effective name.
- Inherited from:
- SymDenotation
The closest enclosing extension method containing this definition, including methods outside the current class.
The closest enclosing extension method containing this definition, including methods outside the current class.
- Inherited from:
- SymDenotation
The closest enclosing method containing this definition. A local dummy owner is mapped to the primary constructor of the class.
The closest enclosing method containing this definition. A local dummy owner is mapped to the primary constructor of the class.
- Inherited from:
- SymDenotation
The package class containing this denotation
The package class containing this denotation
- Inherited from:
- SymDenotation
The class that encloses the owner of the current context and that is a subclass of this class. NoSymbol if no such class exists.
The class that encloses the owner of the current context and that is a subclass of this class. NoSymbol if no such class exists.
- Inherited from:
- SymDenotation
Make sure this denotation is fully completed.
Make sure this denotation is fully completed.
- See also:
completeOnce
- Inherited from:
- SymDenotation
If denotation is private, remove the Private flag and expand the name if necessary
If denotation is private, remove the Private flag and expand the name if necessary
- Inherited from:
- SymDenotation
Is this denotation different from NoDenotation or an ErrorDenotation?
Is this denotation different from NoDenotation or an ErrorDenotation?
- Inherited from:
- Denotation
The expanded name of this denotation.
The expanded name of this denotation.
- Inherited from:
- SymDenotation
Returns all matching symbols defined in parents of the selftype.
Returns all matching symbols defined in parents of the selftype.
- Inherited from:
- SymDenotation
The extension parameter of this extension method
The extension parameter of this extension method
- Inherited from:
- SymDenotation
A fallback text representation, if the pattern matching in Printers does not have a case for this showable element
A fallback text representation, if the pattern matching in Printers does not have a case for this showable element
- Inherited from:
- Showable
Keep only those annotations that satisfy p
Keep only those annotations that satisfy p
- Inherited from:
- SymDenotation
The encoded flat name of this denotation, where joined names are separated by separator
characters.
The encoded flat name of this denotation, where joined names are separated by separator
characters.
- Inherited from:
- SymDenotation
The encoded full path name of this denotation (separated by prefixKind
),
followed by the separator implied by kind
and the given name
.
Drops package objects. Represents each term in the owner chain by a simple _$
.
The encoded full path name of this denotation (separated by prefixKind
),
followed by the separator implied by kind
and the given name
.
Drops package objects. Represents each term in the owner chain by a simple _$
.
- Inherited from:
- SymDenotation
Optionally, the annotation matching the given class symbol
Optionally, the annotation matching the given class symbol
- Inherited from:
- SymDenotation
Does this denotation have an annotation matching the given class symbol?
Does this denotation have an annotation matching the given class symbol?
- Inherited from:
- SymDenotation
Does this symbol have defined or inherited default parameters? Default parameters are recognized until erasure.
Does this symbol have defined or inherited default parameters? Default parameters are recognized until erasure.
- Inherited from:
- SymDenotation
The type info. The info is an instance of TypeType iff this is a type denotation Uncompleted denotations set myInfo to a LazyType.
The type info. The info is an instance of TypeType iff this is a type denotation Uncompleted denotations set myInfo to a LazyType.
- Inherited from:
- Denotation
The type info, or, if symbol is not yet completed, the completer
The type info, or, if symbol is not yet completed, the completer
- Inherited from:
- SymDenotation
Install this denotation as the result of the given denotation transformer.
Install this denotation as the result of the given denotation transformer.
- Definition Classes
- Inherited from:
- SymDenotation
Invalidate all caches and fields that depend on base classes and their contents
Invalidate all caches and fields that depend on base classes and their contents
- Inherited from:
- SingleDenotation
Has this denotation the given flag set, whereas none of the flags
in butNot
are set?
Has this denotation the given flag set, whereas none of the flags
in butNot
are set?
- Inherited from:
- SymDenotation
Has this denotation one of given flag set?
Has this denotation one of given flag set?
- Inherited from:
- SymDenotation
Is symbol known to not exist?
Is symbol known to not exist?
- Value parameters:
- canForce
If this is true, the info may be forced to avoid a false-negative result
- Inherited from:
- SymDenotation
Is this symbol an abstract or alias type?
Is this symbol an abstract or alias type?
- Inherited from:
- SymDenotation
Is this symbol an abstract type or type parameter?
Is this symbol an abstract type or type parameter?
- Inherited from:
- SymDenotation
Is this definition accessible as a member of tree with type pre
?
Is this definition accessible as a member of tree with type pre
?
- Value parameters:
- pre
The type of the tree from which the selection is made
- superAccess
Access is via super Everything is accessible if
pre
isNoPrefix
. A symbol with typeNoType
is not accessible for any other prefix. As a side effect, drop Local flags of members that are not accessed via the ThisType of their owner.
- Inherited from:
- SymDenotation
Has this denotation all of the flags in fs
set, whereas none of the flags
in butNot
are set?
Has this denotation all of the flags in fs
set, whereas none of the flags
in butNot
are set?
- Inherited from:
- SymDenotation
Has this denotation all of the flags in fs
set?
Has this denotation all of the flags in fs
set?
- Inherited from:
- SymDenotation
Is this a Scala or Java annotation ?
Is this a Scala or Java annotation ?
- Inherited from:
- SymDenotation
Is this symbol concrete, or that symbol deferred?
Is this symbol concrete, or that symbol deferred?
- Inherited from:
- SymDenotation
Is this the constructor of a class?
Is this the constructor of a class?
- Inherited from:
- SymDenotation
Do this symbol and cls
represent a pair of a given or implicit method and
its associated class that were defined by a single definition?
This can mean one of two things:
Do this symbol and cls
represent a pair of a given or implicit method and
its associated class that were defined by a single definition?
This can mean one of two things:
- the method and class are defined in a structural given instance, or
- the class is an implicit class and the method is its implicit conversion.
- Inherited from:
- SymDenotation
Is this denotation defined in the same scope and compilation unit as that symbol?
Is this denotation defined in the same scope and compilation unit as that symbol?
- Inherited from:
- SymDenotation
The denotation is completed: info is not a lazy type and attributes have defined values
The denotation is completed: info is not a lazy type and attributes have defined values
- Inherited from:
- SymDenotation
The denotation is in train of being completed
The denotation is in train of being completed
- Inherited from:
- SymDenotation
Is this the constructor of a trait or a class
Is this the constructor of a trait or a class
- Inherited from:
- SymDenotation
Is this definition contained in boundary
?
Same as ownersIterator contains boundary
but more efficient.
Is this definition contained in boundary
?
Same as ownersIterator contains boundary
but more efficient.
- Inherited from:
- SymDenotation
Is this symbol the empty package class or its companion object?
Is this symbol the empty package class or its companion object?
- Inherited from:
- SymDenotation
An erased value or an erased inline method or field
An erased value or an erased inline method or field
- Inherited from:
- SymDenotation
A symbol is effectively final if it cannot be overridden in a subclass
A symbol is effectively final if it cannot be overridden in a subclass
- Inherited from:
- SymDenotation
A class is effectively sealed if has the final
or sealed
modifier, or it
is defined in Scala 3 and is neither abstract nor open.
A class is effectively sealed if has the final
or sealed
modifier, or it
is defined in Scala 3 and is neither abstract nor open.
- Inherited from:
- SymDenotation
Is this symbol the empty package class or its companion object?
Is this symbol the empty package class or its companion object?
- Inherited from:
- SymDenotation
is this symbol the result of an erroneous definition?
is this symbol the result of an erroneous definition?
- Inherited from:
- SymDenotation
A class is extensible if it is not final, nor a module class, nor an anonymous class.
A class is extensible if it is not final, nor a module class, nor an anonymous class.
- Inherited from:
- SymDenotation
Is this a symbol representing an import?
Is this a symbol representing an import?
- Inherited from:
- SymDenotation
A member of class base
is incomplete if
(1) it is declared deferred or
(2) it is abstract override and its super symbol in base
is
nonexistent or incomplete.
A member of class base
is incomplete if
(1) it is declared deferred or
(2) it is abstract override and its super symbol in base
is
nonexistent or incomplete.
- Inherited from:
- SymDenotation
Is this symbol the same or a linked class of sym
?
Is this symbol the same or a linked class of sym
?
- Inherited from:
- SymDenotation
Is this a denotation of a real class that does not have - either direct or inherited - initialization code?
Is this a denotation of a real class that does not have - either direct or inherited - initialization code?
- Inherited from:
- SymDenotation
Is symbol a class for which no runtime representation exists?
Is symbol a class for which no runtime representation exists?
- Inherited from:
- SymDenotation
Is this symbol a class of which null
is a value?
Is this symbol a class of which null
is a value?
- Inherited from:
- SymDenotation
Is this symbol a class of which null
is a value after erasure?
For example, if -Yexplicit-nulls
is set, String
is not nullable before erasure,
but it becomes nullable after erasure.
Is this symbol a class of which null
is a value after erasure?
For example, if -Yexplicit-nulls
is set, String
is not nullable before erasure,
but it becomes nullable after erasure.
- Inherited from:
- SymDenotation
Is symbol a primitive numeric value class?
Is symbol a primitive numeric value class?
- Inherited from:
- SymDenotation
Has this denotation one of the flags in fs
set, whereas none of the flags
in butNot
are set?
Has this denotation one of the flags in fs
set, whereas none of the flags
in butNot
are set?
- Inherited from:
- SymDenotation
Has this denotation one of the flags in fs
set?
Has this denotation one of the flags in fs
set?
- Inherited from:
- SymDenotation
Is this symbol a user-defined opaque alias type?
Is this symbol a user-defined opaque alias type?
- Inherited from:
- SymDenotation
Is this symbol a package object or its module class?
Is this symbol a package object or its module class?
- Inherited from:
- SymDenotation
Does this symbol denote the primary constructor of its enclosing class?
Does this symbol denote the primary constructor of its enclosing class?
- Inherited from:
- SymDenotation
Is this denotation a non-trait class?
Is this denotation a non-trait class?
- Inherited from:
- SymDenotation
Is this a "real" method? A real method is a method which is:
Is this a "real" method? A real method is a method which is:
- not an accessor
- not an anonymous function
- Inherited from:
- SymDenotation
True if the info of this denotation comes from a refinement.
True if the info of this denotation comes from a refinement.
- Inherited from:
- SingleDenotation
Is this symbol a class representing a refinement? These classes are used only temporarily in Typer and Unpickler as an intermediate step for creating Refinement types.
Is this symbol a class representing a refinement? These classes are used only temporarily in Typer and Unpickler as an intermediate step for creating Refinement types.
- Inherited from:
- SymDenotation
Does this method or field need to be retained at runtime
Does this method or field need to be retained at runtime
- Inherited from:
- SymDenotation
Does this method need to be retained at runtime
Does this method need to be retained at runtime
- Inherited from:
- SymDenotation
Is this symbol the root class or its companion object?
Is this symbol the root class or its companion object?
- Inherited from:
- SymDenotation
Is this the denotation of a self symbol of some class? This is the case if one of two conditions holds:
Is this the denotation of a self symbol of some class? This is the case if one of two conditions holds:
- It is the symbol referred to in the selfInfo part of the ClassInfo which is the type of this symbol's owner.
- This symbol is owned by a class, it's selfInfo field refers to a type (indicating the self definition does not introduce a name), and the symbol's name is "_". TODO: Find a more robust way to characterize self symbols, maybe by spending a Flag on them?
- Inherited from:
- SymDenotation
Is this symbol a class that extends java.io.Serializable
?
Is this symbol a class that extends java.io.Serializable
?
- Inherited from:
- SymDenotation
Is this a denotation of a stable term (or an arbitrary type)? Terms are stable if they are idempotent (as in TreeInfo.Idempotent): that is, they always return the same value, if any.
Is this a denotation of a stable term (or an arbitrary type)? Terms are stable if they are idempotent (as in TreeInfo.Idempotent): that is, they always return the same value, if any.
A member is stable, basically, if it behaves like a field projection: that is, it projects a constant result out of its owner.
However, a stable member might not yet be initialized (if it is an object or anyhow lazy). So the first call to a stable member might fail and/or produce side effects.
- Inherited from:
- SymDenotation
Is this denotation static (i.e. with no outer instance)?
Is this denotation static (i.e. with no outer instance)?
- Inherited from:
- SymDenotation
Does this symbol denote the static constructor of its enclosing class?
Does this symbol denote the static constructor of its enclosing class?
- Inherited from:
- SymDenotation
Is this a package class or module class that defines static symbols?
Is this a package class or module class that defines static symbols?
- Inherited from:
- SymDenotation
Is this a reference to a term symbol?
Is this a reference to a term symbol?
- Inherited from:
- Denotation
Is this denotation a type?
Is this denotation a type?
- Definition Classes
- Inherited from:
- SymDenotation
Is this symbol a class that extends AnyVal
?
Is this symbol a class that extends AnyVal
?
- Inherited from:
- SymDenotation
Is this a synthetic method that represents conversions between representations of a value class These methods are generated in ExtensionMethods and used in ElimErasedValueType.
Is this a synthetic method that represents conversions between representations of a value class These methods are generated in ExtensionMethods and used in ElimErasedValueType.
- Inherited from:
- SymDenotation
Symbol is an owner that would be skipped by effectiveOwner. Skipped are
Symbol is an owner that would be skipped by effectiveOwner. Skipped are
- package objects
- non-lazy valdefs
- Inherited from:
- SymDenotation
Is this symbol a toplevel definition in a package object?
Is this symbol a toplevel definition in a package object?
- Inherited from:
- SymDenotation
A class that in source code would be lexically enclosing
A class that in source code would be lexically enclosing
- Inherited from:
- SymDenotation
If this is a class, the module class of its companion object. If this is a module class, its companion class. NoSymbol otherwise.
If this is a class, the module class of its companion object. If this is a module class, its companion class. NoSymbol otherwise.
- Inherited from:
- SymDenotation
- Inherited from:
- SingleDenotation
()T and => T types should be treated as equivalent for this symbol. Note: For the moment, we treat Scala-2 compiled symbols as loose matching, because the Scala library does not always follow the right conventions. Examples are: isWhole(), toInt(), toDouble() in BigDecimal, Numeric, RichInt, ScalaNumberProxy.
()T and => T types should be treated as equivalent for this symbol. Note: For the moment, we treat Scala-2 compiled symbols as loose matching, because the Scala library does not always follow the right conventions. Examples are: isWhole(), toInt(), toDouble() in BigDecimal, Numeric, RichInt, ScalaNumberProxy.
- Inherited from:
- SymDenotation
matches
without a target name check.
matches
without a target name check.
For definitions coming from different languages, we pick a common language to compute their signatures. This allows us for example to override some Java definitions from Scala even if they have a different erasure (see i8615b, i9109b), Erasure takes care of adding any necessary bridge to make this work at runtime.
- Inherited from:
- SingleDenotation
The non-private symbol whose name and type matches the type of this symbol in the given class.
The non-private symbol whose name and type matches the type of this symbol in the given class.
- Value parameters:
- inClass
The class containing the result symbol's definition
- site
The base type from which member types are computed inClass <-- find denot.symbol class C { <-- symbol is here site: Subtype of both inClass and C
- Inherited from:
- SymDenotation
The alternative of this denotation that has a type matching targetType
when seen
as a member of type site
and that has a target name matching targetName
, or
NoDenotation
if none exists.
The alternative of this denotation that has a type matching targetType
when seen
as a member of type site
and that has a target name matching targetName
, or
NoDenotation
if none exists.
- Inherited from:
- Denotation
The non-private member of site
whose name and type matches the type of this symbol
The non-private member of site
whose name and type matches the type of this symbol
- Inherited from:
- SymDenotation
Form a denotation by conjoining with denotation that
.
Form a denotation by conjoining with denotation that
.
NoDenotations are dropped. MultiDenotations are handled by merging parts with same signatures. SingleDenotations with equal signatures are joined by following this sequence of steps:
- If exactly one the denotations has an inaccessible symbol, pick the other one.
- Otherwise, if one of the infos overrides the other one, and the associated symbol does not score strictly lower than the other one, pick the associated denotation.
- Otherwise, if the two infos can be combined with
infoMeet
, pick that as result info, and pick the symbol that scores higher as result symbol, or picksym1
as a tie breaker. The picked info and symbol are combined in a JointDenotation. - Otherwise, if one of the two symbols scores strongly higher than the other one, pick the associated denotation.
- Otherwise return a multi-denotation consisting of both denotations.
Symbol scoring is determined according to the following ranking where earlier criteria trump later ones. Cases marked with (*) give a strong score advantage, the others a weak one.
- The symbol exists, and the other one does not. (*)
- The symbol is not a bridge, but the other one is. (*)
- The symbol is concrete, and the other one is deferred
- The symbol appears before the other in the linearization of
pre
- The symbol's visibility is strictly greater than the other one's.
- The symbol is a method, but the other one is not.
- Inherited from:
- Denotation
If false, this class member cannot possibly participate in an override, either as overrider or overridee.
If false, this class member cannot possibly participate in an override, either as overrider or overridee.
- Inherited from:
- SymDenotation
Do members of this symbol need translation via asSeenFrom when
accessed via prefix pre
?
Do members of this symbol need translation via asSeenFrom when
accessed via prefix pre
?
- Inherited from:
- SymDenotation
If this a module, return the corresponding class, if this is a module, return itself, otherwise NoSymbol
If this a module, return the corresponding class, if this is a module, return itself, otherwise NoSymbol
- Inherited from:
- SymDenotation
The NamedType representing this denotation at its original location.
Same as either typeRef
or termRef
depending whether this denotes a type or not.
The NamedType representing this denotation at its original location.
Same as either typeRef
or termRef
depending whether this denotes a type or not.
- Inherited from:
- SymDenotation
Equivalent to allOverriddenSymbols.headOption.getOrElse(NoSymbol)
but more efficient.
Equivalent to allOverriddenSymbols.headOption.getOrElse(NoSymbol)
but more efficient.
- Inherited from:
- SymDenotation
The alias of an opaque type alias that's stored in the self type of the containing object.
The alias of an opaque type alias that's stored in the self type of the containing object.
- Inherited from:
- SymDenotation
If this is an opaque alias, replace the right hand side info
by appropriate bounds and store info
in the refinement of the
self type of the enclosing class.
Otherwise return info
If this is an opaque alias, replace the right hand side info
by appropriate bounds and store info
in the refinement of the
self type of the enclosing class.
Otherwise return info
- Value parameters:
- info
Is assumed to be a (lambda-abstracted) right hand side TypeAlias of the opaque type definition.
- rhs
The right hand side tree of the type definition
- tparams
The type parameters with which the right-hand side bounds should be abstracted
- Inherited from:
- SymDenotation
If this denotation does not exist, fallback to alternative
If this denotation does not exist, fallback to alternative
- Inherited from:
- Denotation
The effective name with which the denoting symbol was created
The effective name with which the denoting symbol was created
- Inherited from:
- SymDenotation
The owner with which the denoting symbol was created.
The owner with which the denoting symbol was created.
- Inherited from:
- SymDenotation
The symbol, in class inClass
, that is overridden by this denotation in class siteClass
.
The symbol, in class inClass
, that is overridden by this denotation in class siteClass
.
- Inherited from:
- SymDenotation
The symbol overriding this symbol in given subclass ofclazz
.
The symbol overriding this symbol in given subclass ofclazz
.
- Value parameters:
- ofclazz
is a subclass of this symbol's owner
- Inherited from:
- SymDenotation
The owner of the symbol; overridden in NoDenotation
The owner of the symbol; overridden in NoDenotation
- Inherited from:
- SymDenotation
The chain of owners of this denotation, starting with the denoting symbol itself
The chain of owners of this denotation, starting with the denoting symbol itself
- Inherited from:
- SymDenotation
The symbols of each type parameter list and value parameter list of this method, or Nil if this isn't a method.
The symbols of each type parameter list and value parameter list of this method, or Nil if this isn't a method.
Makes use of rawParamss
when present, or constructs fresh parameter symbols otherwise.
This method can be allocation-heavy.
- Inherited from:
- SymDenotation
For SymDenotation, this is NoPrefix. For other denotations this is the prefix under which the denotation was constructed.
For SymDenotation, this is NoPrefix. For other denotations this is the prefix under which the denotation was constructed.
Note that asSeenFrom
might return a SymDenotation
and therefore in
general one cannot rely on prefix
being set, see
Config.reuseSymDenotations
for details.
- Inherited from:
- SingleDenotation
The privateWithin boundary, NoSymbol if no boundary is given.
The privateWithin boundary, NoSymbol if no boundary is given.
- Inherited from:
- SymDenotation
If this is a method, the parameter symbols, by section. Both type and value parameters are included. Empty sections are skipped.
If this is a method, the parameter symbols, by section. Both type and value parameters are included. Empty sections are skipped.
- Inherited from:
- SymDenotation
Like termRef, but objects in the prefix are represented by their singleton type,
this means we output pre.O.member
rather than pre.O$.this.member
.
Like termRef, but objects in the prefix are represented by their singleton type,
this means we output pre.O.member
rather than pre.O$.this.member
.
This is required to avoid owner crash in ExplicitOuter. See tests/pos/i10769.scala
- Inherited from:
- SymDenotation
Like thisType, but objects in the type are represented by their singleton type,
this means we output pre.O.member
rather than pre.O$.this.member
.
Like thisType, but objects in the type are represented by their singleton type,
this means we output pre.O.member
rather than pre.O$.this.member
.
- Inherited from:
- SymDenotation
Like typeRef, but objects in the prefix are represented by their singleton type,
this means we output pre.O.member
rather than pre.O$.this.member
.
Like typeRef, but objects in the prefix are represented by their singleton type,
this means we output pre.O.member
rather than pre.O$.this.member
.
This is required to avoid owner crash in ExplicitOuter. See tests/pos/i10769.scala
- Inherited from:
- SymDenotation
Remove annotation with given class from this denotation
Remove annotation with given class from this denotation
- Inherited from:
- SymDenotation
Return symbol in this denotation that satisfies the given predicate.
if generateStubs is specified, return a stubsymbol if denotation is a missing ref.
Throw a TypeError
if predicate fails to disambiguate symbol or no alternative matches.
Return symbol in this denotation that satisfies the given predicate.
if generateStubs is specified, return a stubsymbol if denotation is a missing ref.
Throw a TypeError
if predicate fails to disambiguate symbol or no alternative matches.
- Inherited from:
- Denotation
Unset given flags(s) of this denotation
Unset given flags(s) of this denotation
- Inherited from:
- SymDenotation
Same as sealedStrictDescendants
but prepends this symbol as well.
Same as sealedStrictDescendants
but prepends this symbol as well.
- Inherited from:
- SymDenotation
Recursively assemble all children of this symbol, Preserves order of insertion.
Recursively assemble all children of this symbol, Preserves order of insertion.
- Inherited from:
- SymDenotation
Set given flags(s) of this denotation
Set given flags(s) of this denotation
- Inherited from:
- SymDenotation
Set flag flags
in current phase and in all phases that follow
Set flag flags
in current phase and in all phases that follow
- Inherited from:
- SymDenotation
Set applicable flags in {NoInits, PureInterface}
Set applicable flags in {NoInits, PureInterface}
- Value parameters:
- bodyFlags
The flags that match the class or trait's body
- parentFlags
The flags that match the class or trait's parents
- Inherited from:
- SymDenotation
The string representation of this showable element.
The string representation of this showable element.
- Inherited from:
- Showable
Show declaration string; useful for showing declarations as seen from subclasses.
Show declaration string; useful for showing declarations as seen from subclasses.
- Inherited from:
- SingleDenotation
The string representation with each line after the first one indented by the given given margin (in spaces).
The string representation with each line after the first one indented by the given given margin (in spaces).
- Inherited from:
- Showable
The summarized string representation of this showable element. Recursion depth is limited to some smallish value. Default is Config.summarizeDepth.
The summarized string representation of this showable element. Recursion depth is limited to some smallish value. Default is Config.summarizeDepth.
- Inherited from:
- Showable
Overload of signature
which lets the caller pick the language used
to compute the signature of the info. Useful to match denotations defined in
different classes (see matchesLoosely
).
Overload of signature
which lets the caller pick the language used
to compute the signature of the info. Useful to match denotations defined in
different classes (see matchesLoosely
).
- Inherited from:
- SingleDenotation
For SymDenotations, the language-specific signature of the info, depending on where the symbol is defined. For non-SymDenotations, the Scala 3 signature.
For SymDenotations, the language-specific signature of the info, depending on where the symbol is defined. For non-SymDenotations, the Scala 3 signature.
Invariants:
- Before erasure, the signature of a denotation is always equal to the signature of its corresponding initial denotation.
- Two distinct overloads will have SymDenotations with distinct signatures (the SELECTin tag in Tasty relies on this to refer to an overload unambiguously). Note that this only applies to SymDenotations, in general we cannot assume that distinct SingleDenotations will have distinct signatures (cf #9050).
- Inherited from:
- SingleDenotation
Skips symbol that are not owned by a class
Skips symbol that are not owned by a class
- Inherited from:
- SymDenotation
Skip any denotations that have been removed by an installAfter or that are otherwise undefined.
Skip any denotations that have been removed by an installAfter or that are otherwise undefined.
- Inherited from:
- SingleDenotation
If this is a weak owner, its owner, otherwise the denoting symbol.
If this is a weak owner, its owner, otherwise the denoting symbol.
- Inherited from:
- SymDenotation
If this a module class, return the corresponding module, if this is a module, return itself, otherwise NoSymbol
If this a module class, return the corresponding module, if this is a module, return itself, otherwise NoSymbol
- Inherited from:
- SymDenotation
The symbol accessed by a super in the definition of this symbol when
seen from class base
. This symbol is always concrete.
pre: this.owner
is in the base class sequence of base
.
The symbol accessed by a super in the definition of this symbol when
seen from class base
. This symbol is always concrete.
pre: this.owner
is in the base class sequence of base
.
- Inherited from:
- SymDenotation
The name given in a @targetName
annotation if one is present, name
otherwise
The name given in a @targetName
annotation if one is present, name
otherwise
- Inherited from:
- SymDenotation
The top-level class containing this denotation, except for a toplevel module, where its module class is returned.
The top-level class containing this denotation, except for a toplevel module, where its module class is returned.
- Inherited from:
- SymDenotation
Apply a transformation f
to all denotations in this group that start at or after
given phase. Denotations are replaced while keeping the same validity periods.
Apply a transformation f
to all denotations in this group that start at or after
given phase. Denotations are replaced while keeping the same validity periods.
- Definition Classes
- Inherited from:
- SymDenotation
Apply transform f
to all annotations of this denotation
Apply transform f
to all annotations of this denotation
- Inherited from:
- SymDenotation
The field accessed by a getter or setter, or if it does not exists, the getter of a setter, or if that does not exist the symbol itself.
The field accessed by a getter or setter, or if it does not exists, the getter of a setter, or if that does not exist the symbol itself.
- Inherited from:
- SymDenotation
The same as getAnnotation, but without ensuring that the symbol carrying the annotation is completed
The same as getAnnotation, but without ensuring that the symbol carrying the annotation is completed
- Inherited from:
- SymDenotation
The symbols defined in this class or object. Careful! This does not force the type, so is compilation order dependent. This method should be used only in the following circumstances:
The symbols defined in this class or object. Careful! This does not force the type, so is compilation order dependent. This method should be used only in the following circumstances:
- When accessing type parameters or type parameter accessors (both are entered before completion).
- When obtaining the current scope in order to enter, rename or delete something there.
- When playing it safe in order not to raise CylicReferences, e.g. for printing things or taking more efficient shortcuts (e.g. the stillValid test).
- Inherited from:
- SymDenotation
Optionally, the info if it is completed
Optionally, the info if it is completed
- Inherited from:
- SymDenotation
Remove any annotations with same class as annot
, and add annot
Remove any annotations with same class as annot
, and add annot
- Inherited from:
- SymDenotation
The variance of this type parameter or type member as a subset of {Covariant, Contravariant}
The variance of this type parameter or type member as a subset of {Covariant, Contravariant}
- Inherited from:
- SymDenotation
Inherited fields
The next SingleDenotation in this run, with wrap-around from last to first.
The next SingleDenotation in this run, with wrap-around from last to first.
There may be several SingleDenotation
s with different validity
representing the same underlying definition at different phases.
These are called a "flock". Flock members are generated by
- Inherited from:
- SingleDenotation