diff options
author | Paul Phillips <paulp@improving.org> | 2009-06-20 16:55:48 +0000 |
---|---|---|
committer | Paul Phillips <paulp@improving.org> | 2009-06-20 16:55:48 +0000 |
commit | 8cf7228f8c1e11d67f4b7053b4ff2772e2bd79fc (patch) | |
tree | 0517282d9e1beb8330a694617504795d6ae2f6c4 /src/library | |
parent | 533764a7180c005024e997246a56ee9fce337bb5 (diff) | |
download | scala-8cf7228f8c1e11d67f4b7053b4ff2772e2bd79fc.tar.gz scala-8cf7228f8c1e11d67f4b7053b4ff2772e2bd79fc.tar.bz2 scala-8cf7228f8c1e11d67f4b7053b4ff2772e2bd79fc.zip |
Created DelayedLazyVal for your def/val hybrid ...
Created DelayedLazyVal for your def/val hybrid needs.
Diffstat (limited to 'src/library')
-rw-r--r-- | src/library/scala/concurrent/DelayedLazyVal.scala | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/src/library/scala/concurrent/DelayedLazyVal.scala b/src/library/scala/concurrent/DelayedLazyVal.scala new file mode 100644 index 0000000000..0fa3c1660b --- /dev/null +++ b/src/library/scala/concurrent/DelayedLazyVal.scala @@ -0,0 +1,44 @@ +/* __ *\ +** ________ ___ / / ___ Scala API ** +** / __/ __// _ | / / / _ | (c) 2003-2009, LAMP/EPFL ** +** __\ \/ /__/ __ |/ /__/ __ | ** +** /____/\___/_/ |_/____/_/ | | ** +** |/ ** +\* */ + +// $Id$ + +package scala.concurrent + +import annotation.experimental + +/** A <code>DelayedLazyVal</code> is a wrapper for lengthy + * computations which have a valid partially computed result. + * The first argument is a function for obtaining the result + * at any given point in time, and the second is the lengthy + * computation. Once the computation is complete, the apply() + * method will stop recalculating it and return a fixed value + * from that point forward. + * + * @param f the function to obtain the current value at any point in time + * @param body the computation to run to completion in another thread + * + * @author Paul Phillips + * @version 2.8 + */ +@experimental +class DelayedLazyVal[T](f: () => T, body: => Unit) { + @volatile private[this] var isDone = false + private[this] lazy val complete = f() + + /** The current result of f(), or the final result if complete. + * + * @return the current value + */ + def apply(): T = if (isDone) complete else f() + + ops.future { + body + isDone = true + } +}
\ No newline at end of file |