Newer
Older
gitbucket_jkp / src / main / scala / util / Implicits.scala
@takezoe takezoe on 29 Jun 2013 917 bytes Add TODO.
package util

import twirl.api.Html
import scala.slick.driver.H2Driver.simple._

/**
 * Provides some usable implicit conversions.
 */
object Implicits {
  
  implicit def extendsSeq[A](seq: Seq[A]) = new {

    def splitWith(condition: (A, A) => Boolean): Seq[Seq[A]] = split(seq)(condition)

    @scala.annotation.tailrec
    private def split[A](list: Seq[A], result: Seq[Seq[A]] = Nil)(condition: (A, A) => Boolean): Seq[Seq[A]] = {
      list match {
        case x :: xs => {
          xs.span(condition(x, _)) match {
            case (matched, remained) => split(remained, result :+ (x :: matched))(condition)
          }
        }
        case Nil => result
      }
    }
  }

  // TODO Should this implicit conversion move to model.Functions?
  implicit def extendsColumn(c1: Column[Boolean]) = new {
    def &&(c2: => Column[Boolean], guard: => Boolean): Column[Boolean] = if(guard) c1 && c2 else c1
  }

}