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

no.kodeworks.kvarg.util.package.scala Maven / Gradle / Ivy

package no.kodeworks.kvarg

import akka.actor.Cancellable
import shapeless.{HList, LowPriority, Typeable, Witness, tag}
import shapeless.tag.{@@, Tagged}
import cats.syntax.option._

import scala.concurrent.{ExecutionContext, Future, Promise}
import scala.util.Try

package object util {

  object emptyCancellable extends Cancellable {
    override def cancel() = true

    override def isCancelled = true
  }

  implicit class RichFuture[T](f: Future[T]) {
    def mapAll[Target](m: Try[T] => Target)(implicit ec: ExecutionContext): Future[Target] = {
      val promise = Promise[Target]()
      f.onComplete { r => promise success m(r) }(ec)
      promise.future
    }

    def flatMapAll[Target](m: Try[T] => Future[Target])(implicit ec: ExecutionContext): Future[Target] = {
      val promise = Promise[Target]()
      f.onComplete { r => m(r).onComplete { z => promise complete z }(ec) }(ec)
      promise.future
    }
  }

  def seqFutures[T, U]
  (ts: TraversableOnce[T])
  (ff: T => Future[U])
  (implicit ec: ExecutionContext): Future[List[U]] = {
    ts.foldLeft(Future.successful[List[U]](Nil)) {
      (f, item) =>
        f.flatMap {
          x => ff(item).map(_ :: x)
        }
    } map (_.reverse)
  }

  def lowerFirstChar(s: String): String =
    (s.head + 32).toChar.toString + s.substring(1)

  def typeableToSimpleName(tt: Typeable[_], firstCharAsLowerCase: Boolean = true): String = {
    val s = tt.describe
    val s1 = (s.lastIndexOf('.') match {
      case -1 => s
      case i => s.substring(i + 1)
    })
    val s2 = s1.indexOf('[') match {
      case -1 => s1
      case i => s.substring(0, i)
    }
    if (firstCharAsLowerCase) lowerFirstChar(s2)
    else s2
  }

  def hlistToList[T](hlist: shapeless.HList): List[T] = {
    import shapeless._
    hlist match {
      case HNil => Nil
      case head :: tail =>
        collection.immutable.::(head.asInstanceOf[T], hlistToList[T](tail))
    }
  }

  def listToHList[H <: HList](list: List[_]): H = {
    import shapeless._
    (list match {
      case Nil => HNil
      case collection.immutable.::(head, tail) =>
        (head :: listToHList[H](tail))
    }).asInstanceOf[H]
  }

  /** Typeable instance for `Tagged[U]`. */
  implicit def taggedTypeable[U]
  (implicit
   castU: Typeable[U]
  ): Typeable[Tagged[U]] =
    new Typeable[Tagged[U]] {
      def cast(tu: Any): Option[Tagged[U]] = {
        if (tu == null) None
        else if (tu.isInstanceOf[Tagged[U]]) {
          val o = tu.asInstanceOf[Tagged[U]]
          o.some
        } else None
      }

      def describe = s"Tagged[${typeableToSimpleName(castU, false)}]"
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy