From ffd7b9649cde61553f16c25f64c3072ecfa6c713 Mon Sep 17 00:00:00 2001 From: Philipp Haller Date: Tue, 26 Feb 2013 01:16:40 +0100 Subject: Remove CPS dependency from default async implementation - move all CPS-related code to `continuations` sub package - fix CPS-based async implementation - enable testing of CPS-based async implementation --- .../async/continuations/AsyncWithCPSFallback.scala | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 src/main/scala/scala/async/continuations/AsyncWithCPSFallback.scala (limited to 'src/main/scala/scala/async/continuations/AsyncWithCPSFallback.scala') diff --git a/src/main/scala/scala/async/continuations/AsyncWithCPSFallback.scala b/src/main/scala/scala/async/continuations/AsyncWithCPSFallback.scala new file mode 100644 index 0000000..fe6e1a6 --- /dev/null +++ b/src/main/scala/scala/async/continuations/AsyncWithCPSFallback.scala @@ -0,0 +1,20 @@ +/* + * Copyright (C) 2012 Typesafe Inc. + */ + +package scala.async +package continuations + +import scala.language.experimental.macros + +import scala.reflect.macros.Context +import scala.concurrent.Future + +trait AsyncWithCPSFallback extends AsyncBaseWithCPSFallback with ScalaConcurrentCPSFallback + +object AsyncWithCPSFallback extends AsyncWithCPSFallback { + + def async[T](body: T) = macro asyncImpl[T] + + override def asyncImpl[T: c.WeakTypeTag](c: Context)(body: c.Expr[T]): c.Expr[Future[T]] = super.asyncImpl[T](c)(body) +} -- cgit v1.2.3