dotty.tools.dotc.transform.PatternMatcher.Translator.TreeMakers

ProductExtractorTreeMaker

Related Doc: package TreeMakers

case class ProductExtractorTreeMaker(prevBinder: Symbol, extraCond: Option[ast.tpd.Tree])(subPatBinders: List[Symbol], subPatRefs: List[ast.tpd.Tree], mutableBinders: List[Symbol], binderKnownNonNull: Boolean, ignoredSubPatBinders: Set[Symbol]) extends FunTreeMaker with PreserveSubPatBinders with Product with Serializable

An optimized version of ExtractorTreeMaker for Products. For now, this is hard-coded to case classes, and we simply extract the case class fields.

The values for the subpatterns, as specified by the case class fields at the time of extraction, are stored in local variables that re-use the symbols in subPatBinders. This makes extractor patterns more debuggable (SI-5739) as well as avoiding mutation after the pattern has been matched (SI-5158, SI-6070)

TODO: make this user-definable as follows When a companion object defines a method def unapply_1(x: T): U_1, but no def unapply or def unapplySeq, the extractor is considered to match any non-null value of type T the pattern is expected to have as many sub-patterns as there are def unapply_I(x: T): U_I methods, and the type of the I'th sub-pattern is U_I. The same exception for Seq patterns applies: if the last extractor is of type Seq[U_N], the pattern must have at least N arguments (exactly N if the last argument is annotated with : _*). The arguments starting at N (and beyond) are taken from the sequence returned by apply_N, and it is checked that the sequence has enough elements to provide values for all expected sub-patterns.

For a case class C, the implementation is assumed to be def unapply_I(x: C) = x._I, and the extractor call is inlined under that assumption.

Linear Supertypes
Serializable, Serializable, Product, Equals, PreserveSubPatBinders, FunTreeMaker, TreeMaker, AnyRef, Any
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. ProductExtractorTreeMaker
  2. Serializable
  3. Serializable
  4. Product
  5. Equals
  6. PreserveSubPatBinders
  7. FunTreeMaker
  8. TreeMaker
  9. AnyRef
  10. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Instance Constructors

  1. new ProductExtractorTreeMaker(prevBinder: Symbol, extraCond: Option[ast.tpd.Tree])(subPatBinders: List[Symbol], subPatRefs: List[ast.tpd.Tree], mutableBinders: List[Symbol], binderKnownNonNull: Boolean, ignoredSubPatBinders: Set[Symbol])

Value Members

  1. final def !=(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  5. def bindSubPats(in: ast.tpd.Tree): ast.tpd.Tree

    Definition Classes
    PreserveSubPatBinders
  6. def chainBefore(next: ast.tpd.Tree)(casegen: TreeMakers.Casegen): ast.tpd.Tree

    Definition Classes
    ProductExtractorTreeMakerTreeMaker
  7. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. def emitVars: Boolean

    Definition Classes
    PreserveSubPatBinders
  9. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  10. val extraCond: Option[ast.tpd.Tree]

  11. def extraStoredBinders: Set[Symbol]

  12. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  13. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  14. val ignoredSubPatBinders: Set[Symbol]

  15. lazy val introducedRebindings: Rebindings

    Attributes
    protected
    Definition Classes
    PreserveSubPatBindersTreeMaker
  16. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  17. val mutableBinders: List[Symbol]

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

    Definition Classes
    AnyRef
  19. val nextBinder: Symbol

  20. final def notify(): Unit

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

    Definition Classes
    AnyRef
  22. def pos: Position

    Definition Classes
    FunTreeMakerTreeMaker
  23. val prevBinder: Symbol

  24. def rebindings: Rebindings

    captures the scope and the value of the bindings in patterns important *when* the substitution happens (can't accumulate and do at once after the full matcher has been constructed)

    captures the scope and the value of the bindings in patterns important *when* the substitution happens (can't accumulate and do at once after the full matcher has been constructed)

    Definition Classes
    TreeMaker
  25. def stored: Traversable[(Symbol, ast.tpd.Tree)]

    Definition Classes
    PreserveSubPatBinders
  26. lazy val storedBinders: Set[Symbol]

    Definition Classes
    PreserveSubPatBinders
  27. lazy val storedSubsted: (Traversable[(Symbol, ast.tpd.Tree)], Traversable[(Symbol, ast.tpd.Tree)])

    Definition Classes
    PreserveSubPatBinders
  28. val subPatBinders: List[Symbol]

  29. val subPatRefs: List[ast.tpd.Tree]

  30. def subPatternsAsRebindings: Rebindings

    The substitution that specifies the trees that compute the values of the subpattern binders.

    The substitution that specifies the trees that compute the values of the subpattern binders.

    We pretend to replace the subpattern binders by subpattern refs (Even though we don't do so anymore -- see SI-5158, SI-5739 and SI-6070.)

    Definition Classes
    PreserveSubPatBindersTreeMaker
  31. def substed: Traversable[(Symbol, ast.tpd.Tree)]

    Definition Classes
    PreserveSubPatBinders
  32. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  33. def toString(): String

    Definition Classes
    ProductExtractorTreeMaker → AnyRef → Any
  34. final def wait(): Unit

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

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

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from Serializable

Inherited from Serializable

Inherited from Product

Inherited from Equals

Inherited from PreserveSubPatBinders

Inherited from FunTreeMaker

Inherited from TreeMaker

Inherited from AnyRef

Inherited from Any

Ungrouped