aboutsummaryrefslogblamecommitdiff
path: root/src/main/scala/com/drivergrp/core/core.scala
blob: cfa96e7f54f70d8c02e4ef8b91dc8692853ab250 (plain) (tree)
1
2
3
4
5
6
                     
 

                     
                   
 















                                                               



                                                   



                                                             


                                                                            
   



                                                                 


                                                                                  

   






                                                                                                
 
package com.drivergrp

import java.util.UUID

import scalaz.Equal

package object core {
  import scala.language.reflectiveCalls

  def make[T](v: => T)(f: T => Unit): T = {
    val value = v; f(value); value
  }

  def using[R <: { def close() }, P](r: => R)(f: R => P): P = {
    val resource = r
    try {
      f(resource)
    } finally {
      resource.close()
    }
  }

  object tagging {
    private[core] trait Tagged[+V, +Tag]
  }
  type @@[+V, +Tag] = V with tagging.Tagged[V, Tag]

  type Id[+Tag] = Long @@ Tag
  object Id {
    def apply[Tag](value: Long) = value.asInstanceOf[Id[Tag]]

    implicit def idEqual[T]: Equal[Id[T]]       = Equal.equal[Id[T]](_ == _)
    implicit def idOrdering[T]: Ordering[Id[T]] = Ordering.by(identity)
  }

  type Name[+Tag] = String @@ Tag
  object Name {
    def apply[Tag](value: String) = value.asInstanceOf[Name[Tag]]

    implicit def nameEqual[T]: Equal[Name[T]]       = Equal.equal[Name[T]](_ == _)
    implicit def nameOrdering[T]: Ordering[Name[T]] = Ordering.by(identity)
  }

  object revision {
    final case class Revision[T](id: UUID)

    object Revision {
      implicit def revisionEqual[T]: Equal[Revision[T]] = Equal.equal[Revision[T]](_.id == _.id)
    }
  }
}