diff options
author | Haoyi Li <haoyi@haoyi-mbp.corp.dropbox.com> | 2014-11-26 00:45:31 -0800 |
---|---|---|
committer | Haoyi Li <haoyi@haoyi-mbp.corp.dropbox.com> | 2014-11-26 00:45:31 -0800 |
commit | 24f31e120f9537faede7a174bb09ee35f64e1ce4 (patch) | |
tree | 06ffc3ecc7847789008352b7e2b7c040dad48907 /examples/scala-js/tools/shared/src/main/scala/scala/scalajs/tools/io/CacheUtils.scala | |
parent | b89ce9cbf79363f8cab09186a5d7ba94bc0af02a (diff) | |
parent | 2c4b142503bd2d871e6818b5cab8c38627d9e4a0 (diff) | |
download | hands-on-scala-js-24f31e120f9537faede7a174bb09ee35f64e1ce4.tar.gz hands-on-scala-js-24f31e120f9537faede7a174bb09ee35f64e1ce4.tar.bz2 hands-on-scala-js-24f31e120f9537faede7a174bb09ee35f64e1ce4.zip |
Merge commit '2c4b142503bd2d871e6818b5cab8c38627d9e4a0' as 'examples/scala-js'
Diffstat (limited to 'examples/scala-js/tools/shared/src/main/scala/scala/scalajs/tools/io/CacheUtils.scala')
-rw-r--r-- | examples/scala-js/tools/shared/src/main/scala/scala/scalajs/tools/io/CacheUtils.scala | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/examples/scala-js/tools/shared/src/main/scala/scala/scalajs/tools/io/CacheUtils.scala b/examples/scala-js/tools/shared/src/main/scala/scala/scalajs/tools/io/CacheUtils.scala new file mode 100644 index 0000000..14773f8 --- /dev/null +++ b/examples/scala-js/tools/shared/src/main/scala/scala/scalajs/tools/io/CacheUtils.scala @@ -0,0 +1,52 @@ +package scala.scalajs.tools.io + +object CacheUtils { + + def joinVersions(vs: Option[String]*): Option[String] = { + val bld = new StringBuilder + + @scala.annotation.tailrec + def loop(vs: Seq[Option[String]]): Option[String] = { + vs match { + case Some(v) :: vss => + bld.append(mangleVersionString(v)) + loop(vss) + case None :: _ => + None + case Nil => + Some(bld.toString) + } + } + + loop(vs.toList) + } + + def joinVersions(vs: String*): String = + vs.map(mangleVersionString _).mkString + + private def mangleVersionString(str: String) = s"${str.length}:$str" + + def cached(version: Option[String], output: VirtualFile, + cache: Option[WritableVirtualTextFile])(action: => Unit): Unit = { + + val upToDate = output.exists && ( + for { + v <- version + c <- cache if c.exists + } yield c.content == v + ).getOrElse(false) + + // Are we outdated? + if (!upToDate) { + action + + // Write cache + for (c <- cache; v <- version) { + val w = c.contentWriter + try w.write(v) + finally w.close() + } + } + } + +} |