final case class Aggregate(sym: TermSymbol, from: Node, select: Node) extends BinaryNode with DefNode with Product with Serializable
An aggregation function application which is similar to a Bind(_, _, Pure(_)) where the projection contains a mapping function application. The return type is an aggregated scalar value though, not a collection.
- Source
- Node.scala
- Alphabetic
- By Inheritance
- Aggregate
- Serializable
- Product
- Equals
- DefNode
- BinaryNode
- Node
- Dumpable
- AnyRef
- Any
- by any2stringadd
- by StringFormat
- by Ensuring
- by ArrowAssoc
- Hide All
- Show All
- Public
- Protected
Instance Constructors
- new Aggregate(sym: TermSymbol, from: Node, select: Node)
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): (Aggregate, B)
- final def :@(newType: Type): Self
Return this Node with a Type assigned (if no other type has been seen for it yet) or a typed copy.
Return this Node with a Type assigned (if no other type has been seen for it yet) or a typed copy.
- Definition Classes
- Node
- final def ==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def asInstanceOf[T0]: T0
- Definition Classes
- Any
- final def buildCopy: Self
Build a copy of this node with the current children.
Build a copy of this node with the current children.
- Attributes
- protected[this]
- Definition Classes
- BinaryNode → Node
- def childNames: Seq[String]
Names for the child nodes to show in AST dumps.
- lazy val children: ConstArray[Node]
All child nodes of this node.
All child nodes of this node. Must be implemented by subclasses.
- Definition Classes
- BinaryNode → Node
- final def childrenForeach[R](f: (Node) => R): Unit
Apply a side-effecting function to all direct children from left to right.
Apply a side-effecting function to all direct children from left to right. Note that
n.childrenForeach(f)
is equivalent to
n.children.foreach(f)
but can be implemented more efficiently in
Node
subclasses.- Definition Classes
- BinaryNode → Node
- def clone(): AnyRef
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.CloneNotSupportedException]) @HotSpotIntrinsicCandidate() @native()
- def ensuring(cond: (Aggregate) => Boolean, msg: => Any): Aggregate
- def ensuring(cond: (Aggregate) => Boolean): Aggregate
- def ensuring(cond: Boolean, msg: => Any): Aggregate
- def ensuring(cond: Boolean): Aggregate
- final def eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- val from: Node
- def generators: ConstArray[(TermSymbol, Node)]
- final def getClass(): Class[_ <: AnyRef]
- Definition Classes
- AnyRef → Any
- Annotations
- @HotSpotIntrinsicCandidate() @native()
- def getDumpInfo: DumpInfo
Return the name, main info, attribute info and named children
- def hasType: Boolean
Check if this node has a type without marking the type as seen.
Check if this node has a type without marking the type as seen.
- Definition Classes
- Node
- final def infer(scope: Scope = Map.empty, typeChildren: Boolean = false): Self
Rebuild this node and all children with their computed type.
Rebuild this node and all children with their computed type. If this node already has a type, the children are only type-checked again if
is true. iftypeChildren
is also true, the existing type of this node is replaced. If this node does not yet have a type, the types of all children are computed first.retype
- Definition Classes
- Node
- final def isInstanceOf[T0]: Boolean
- Definition Classes
- Any
- def left: Node
- Definition Classes
- Aggregate → BinaryNode
- final def mapChildren(f: (Node) => Node, keepType: Boolean = false): Self
Apply a mapping function to all children of this node and recreate the node with the new children.
Apply a mapping function to all children of this node and recreate the node with the new children. If all new children are identical to the old ones, this node is returned. If
is true, the type of this node is kept even when the children have changed.keepType
- Definition Classes
- BinaryNode → Node
- final def mapScopedChildren(f: (Option[TermSymbol], Node) => Node): Self with DefNode
- Definition Classes
- DefNode
- final def mapSymbols(f: (TermSymbol) => TermSymbol): Node
- Definition Classes
- DefNode
- final def ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- def nodeType: Type
The current type of this node.
The current type of this node.
- Definition Classes
- Node
- final def notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @HotSpotIntrinsicCandidate() @native()
- final def notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @HotSpotIntrinsicCandidate() @native()
- def peekType: Type
Get the current type of this node for debug output without marking it as seen.
Get the current type of this node for debug output without marking it as seen.
- Attributes
- protected[this]
- Definition Classes
- Node
- def productElementNames: Iterator[String]
- Definition Classes
- Product
- def rebuild(left: Node, right: Node): Aggregate
- Attributes
- protected[this]
- Definition Classes
- Aggregate → BinaryNode
- final def rebuild(ch: ConstArray[Node]): Self
Rebuild this node with a new list of children.
Rebuild this node with a new list of children. Implementations of this method must not reuse the current node. This method always returns a fresh copy.
- Attributes
- protected[this]
- Definition Classes
- BinaryNode → Node
- def rebuildWithSymbols(gen: ConstArray[TermSymbol]): Aggregate
- def right: Node
- Definition Classes
- Aggregate → BinaryNode
- val select: Node
- def self: Aggregate
- val sym: TermSymbol
- final def synchronized[T0](arg0: => T0): T0
- Definition Classes
- AnyRef
- final def toString(): String
- Definition Classes
- Node → AnyRef → Any
- final def untyped: Self
Return this Node with no Type assigned (if it has not yet been observed) or an untyped copy.
Return this Node with no Type assigned (if it has not yet been observed) or an untyped copy.
- Definition Classes
- Node
- final def wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException]) @native()
- final def wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def withChildren(ch2: ConstArray[Node]): Self
Rebuild this node with new child nodes unless all children are identical to the current ones, in which case this node is returned.
Rebuild this node with new child nodes unless all children are identical to the current ones, in which case this node is returned.
- Definition Classes
- Node
- def withInferredType(scope: Scope, typeChildren: Boolean): Self
Deprecated Value Members
- def finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable]) @Deprecated
- Deprecated
(Since version 9)
- def formatted(fmtstr: String): String
- Implicit
- This member is added by an implicit conversion from Aggregate toStringFormat[Aggregate] performed by method StringFormat in scala.Predef.
- Definition Classes
- StringFormat
- Annotations
- @deprecated @inline()
- Deprecated
(Since version 2.12.16) Use
formatString.format(value)
instead ofvalue.formatted(formatString)
, or use thef""
string interpolator. In Java 15 and later,formatted
resolves to the new method in String which has reversed parameters.
- def →[B](y: B): (Aggregate, B)
- Implicit
- This member is added by an implicit conversion from Aggregate toArrowAssoc[Aggregate] performed by method ArrowAssoc in scala.Predef.
- Definition Classes
- ArrowAssoc
- Annotations
- @deprecated
- Deprecated
(Since version 2.13.0) Use
->
instead. If you still wish to display it as one character, consider using a font with programming ligatures such as Fira Code.
edit this text on github
Scala Language-Integrated Connection Kit
This is the API documentation for the Slick database library. It should be used as an additional resource to the user manual.
Further documentation for Slick can be found on the documentation pages.
To the slick package list...