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

quasar.physical.mongodb.accumulator.package.scala Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2014–2017 SlamData Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package quasar.physical.mongodb

import slamdata.Predef._
import quasar.physical.mongodb.expression._
import quasar.physical.mongodb.expression.DocVar

import matryoshka._
import matryoshka.data.Fix
import matryoshka.implicits._
import scalaz._, Scalaz._

package object accumulator {

  def rewriteGroupRefs[EX[_]: Functor](t: AccumOp[Fix[EX]])(applyVar: PartialFunction[DocVar, DocVar])
      (implicit exprOps: ExprOpOps.Uni[EX]): AccumOp[Fix[EX]] =
    t.map(_.cata(exprOps.rewriteRefs(applyVar)))

  val groupBsonƒ: AccumOp[Bson] => Bson = {
    case $addToSet(value) => Bson.Doc("$addToSet" -> value)
    case $push(value)     => Bson.Doc("$push" -> value)
    case $first(value)    => Bson.Doc("$first" -> value)
    case $last(value)     => Bson.Doc("$last" -> value)
    case $max(value)      => Bson.Doc("$max" -> value)
    case $min(value)      => Bson.Doc("$min" -> value)
    case $avg(value)      => Bson.Doc("$avg" -> value)
    case $sum(value)      => Bson.Doc("$sum" -> value)
  }

  def groupBson[EX[_]: Functor](g: AccumOp[Fix[EX]])(implicit exprOps: ExprOpOps.Uni[EX]) =
    groupBsonƒ(g.map(_.cata(exprOps.bson)))
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy