Конвертировать scala 2.10 future в scalaz.concurrent.Future // Задача
Кто -нибудь пришел к фрагменту кода, как правильно преобразовать Scala's Future (2.10) в новое scalaz7 будущее? Я знаю, как конвертировать скалярное будущее через скала Promise в скала Будущее, но не знаю, как это сделать правильно.
Например
import scalaz.concurrent.{Future => Zuture}
import scala.concurrent.Future
Я хочу иметь реализацию
implicit def scalaF2scalazF[A](in:Future[A]):Zuture[A]=???
Тогда, очевидно, будет кусок пирога, чтобы написать
implicit def scalaF2scalazTask[A](in:Future[A]):Task[A]=???
потому что это то, что я действительно хочу:-)
2 ответа
Оценив пару альтернатив, я пришел к следующему решению. Очевидно, если кто-то хочетscalaz.Monad[scala.concurrent.Future]
, scalaz.std.scalaFuture
https://github.com/scalaz/scalaz/blob/series/7.2.x/core/src/main/scala/scalaz/std/Future.scala - это путь.
object ScalaFutureConverters {
implicit def scalaFuture2scalazTask[T](fut: Future[T])(implicit ec: ExecutionContext): Task[T] = {
Task.async {
register =>
fut.onComplete {
case Success(v) => register(v.right)
case Failure(ex) => register(ex.left)
}
}
}
implicit def scalazTask2scalaFuture[T](task: Task[T]): Future[T] = {
val p: Promise[T] = Promise()
task.runAsync {
case -\/(ex) => p.failure(ex)
case \/-(r) => p.success(r)
}
p.future
}
implicit class ScalazFutureEnhancer[T](task: Task[T]) {
def asScala: Future[T] = scalazTask2scalaFuture(task)
}
implicit def scalaF2EnhancedScalaF[T](fut: Future[T])(implicit ec: ExecutionContext): ScalaFEnhancer[T] =
ScalaFEnhancer(fut)(ec)
case class ScalaFEnhancer[T](fut: Future[T])(implicit ec: ExecutionContext) {
def asTask: Task[T] = scalaFuture2scalazTask(fut)(ec)
}
}
Это решение, однако, также запускает задачу после того, как выполнено преобразование в Scala Future, что может / не может быть желательным в зависимости от ситуации.
Вы также можете использовать https://github.com/Verizon/delorean который добавляет удобный toTask
а также toFuture
методы