All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scala.annotation.internal.WitnessNames.scala Maven / Gradle / Ivy

package scala.annotation
package internal

/** An annotation that is used for marking type definitions that should get
 *  context bound companions. The scheme is as follows:
 *
 *  1. When desugaring a context-bounded type A, add a @WitnessNames(n_1, ... , n_k)
 *  annotation to the type declaration node, where n_1, ..., n_k are the names of
 *  all the witnesses generated for the context bounds of A. This annotation will
 *  be pickled as usual.
 *
 *  2. During Namer or Unpickling, when encountering a type declaration A with
 *  a WitnessNames(n_1, ... , n_k) annotation, create a CB companion `val A` with
 *  type ``[ref_1 | ... | ref_k] where ref_i is a TermRef
 *  with the same prefix as A and name n_i. Except, don't do this if the type in
 *  question is a type parameter and there is already a term parameter with name A
 *  defined for the same method.
 *
 *  ContextBoundCompanion is defined as an internal abstract type like this:
 *
 *     type ``[-Refs]
 *
 *  The context bound companion's variance is negative, so that unions in the
 *  arguments are joined when encountering multiple definfitions and forming a glb.
 *
 *  3. Add a special case for typing a selection A.m on a value A of type
 *  ContextBoundCompanion[ref_1, ..., ref_k]. Namely, try to typecheck all
 *  selections ref_1.m, ..., ref_k.m with the expected type. There must be
 *  a unique selection ref_i.m that typechecks and such that for all other
 *  selections ref_j.m that also typecheck one of the following three criteria
 *  applies:
 *
 *    1. ref_i.m and ref_j.m are the same. This means: If they are types then
 *       ref_i.m is an alias of ref_j.m. If they are terms then they are both
 *       singleton types and ref_i.m =:= ref_j.m.
 *    2. The underlying type (under widen) of ref_i is a true supertype of the
 *       underlying type of ref_j.
 *    3. ref_i.m is a term, the underlying type of ref_j is not a strict subtype
 *       of the underlying type of ref_i, and the underlying type ref_i.m is a
 *       strict subtype of the underlying type of ref_j.m.
 *
 *  If there is such a selection, map A.m to ref_i.m, otherwise report an error.
 *
 *  (2) might surprise. It is the analogue of given disambiguation, where we also
 *  pick the most general candidate that matches the expected type. E.g. we have
 *  context bounds for Functor, Monad, and Applicable. In this case we want to
 *  select the `map` method of `Functor`.
 *
 *  4. At PostTyper, issue an error when encountering any reference to a CB companion.
 */
@experimental
class WitnessNames(names: String*) extends StaticAnnotation






© 2015 - 2025 Weber Informatics LLC | Privacy Policy