From 22784be9a32f558c58ebe9d229d574ec893f8a47 Mon Sep 17 00:00:00 2001 From: Antonio Cunei Date: Fri, 1 Dec 2017 05:03:48 +0100 Subject: [PATCH 1/4] Convert lastModified() to sbt.io.Milli.getModifiedTime(), more precise --- .../scala/sbt/internal/inc/classpath/ClassLoaderCache.scala | 3 ++- internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala | 3 ++- project/Util.scala | 2 ++ .../main/scala/sbt/internal/inc/caching/ClasspathCache.scala | 3 ++- 4 files changed, 8 insertions(+), 3 deletions(-) diff --git a/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala b/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala index a700961544..1010655bbc 100644 --- a/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala +++ b/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala @@ -14,6 +14,7 @@ import java.lang.ref.{ Reference, SoftReference } import java.io.File import java.net.URLClassLoader import java.util.HashMap +import sbt.io.Milli.getModifiedTime // Hack for testing only final class ClassLoaderCache(val commonParent: ClassLoader) { @@ -43,7 +44,7 @@ final class ClassLoaderCache(val commonParent: ClassLoader) { mkLoader: () => ClassLoader ): ClassLoader = synchronized { - val tstamps = files.map(_.lastModified) + val tstamps = files.map(getModifiedTime) getFromReference(files, tstamps, delegate.get(files), mkLoader) } diff --git a/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala b/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala index 5ad186f200..5191c22fdd 100644 --- a/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala +++ b/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala @@ -15,6 +15,7 @@ import java.util.Optional import sbt.io.{ Hash => IOHash } import xsbti.compile.analysis.{ ReadStamps, Stamp } +import sbt.io.Milli.getModifiedTime import scala.collection.immutable.TreeMap import scala.util.matching.Regex @@ -142,7 +143,7 @@ object Stamper { } val forHash = (toStamp: File) => tryStamp(Hash.ofFile(toStamp)) - val forLastModified = (toStamp: File) => tryStamp(new LastModified(toStamp.lastModified())) + val forLastModified = (toStamp: File) => tryStamp(new LastModified(getModifiedTime(toStamp))) } object Stamps { diff --git a/project/Util.scala b/project/Util.scala index 0443d9a801..e2eec528d3 100644 --- a/project/Util.scala +++ b/project/Util.scala @@ -21,6 +21,8 @@ object Util { val timestamp = formatter.format(new Date) val content = versionLine(version) + "\ntimestamp=" + timestamp val f = dir / "incrementalcompiler.version.properties" + // TODO: replace lastModified() with sbt.io.Milli.getModifiedTime(), once the build + // has been upgraded to a version of sbt that includes sbt.io.Milli. if (!f.exists || f.lastModified < lastCompilationTime(analysis) || !containsVersion(f, version)) { s.log.info("Writing version information to " + f + " :\n" + content) IO.write(f, content) diff --git a/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala b/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala index 3ccd84dc41..71549fcf57 100644 --- a/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala +++ b/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala @@ -7,6 +7,7 @@ import java.nio.file.attribute.{ BasicFileAttributes, FileTime } import xsbti.compile.FileHash import sbt.internal.inc.{ EmptyStamp, Stamper } +import sbt.io.Milli.getModifiedTime object ClasspathCache { // For more safety, store both the time and size @@ -29,7 +30,7 @@ object ClasspathCache { val attrs = Files.readAttributes(file.toPath, classOf[BasicFileAttributes]) if (attrs.isDirectory) emptyFileHash(file) else { - val currentMetadata = (attrs.lastModifiedTime(), attrs.size()) + val currentMetadata = (FileTime.fromMillis(getModifiedTime(file)), attrs.size()) Option(cacheMetadataJar.get(file)) match { case Some((metadata, hashHit)) if metadata == currentMetadata => hashHit case _ => genFileHash(file, currentMetadata) From 422340c8e0abb31a0cc42c9e3ff3c726498c8028 Mon Sep 17 00:00:00 2001 From: Antonio Cunei Date: Mon, 4 Dec 2017 22:21:35 +0100 Subject: [PATCH 2/4] Moved Milli._ to IO. --- .../scala/sbt/internal/inc/classpath/ClassLoaderCache.scala | 2 +- internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala | 2 +- .../main/scala/sbt/internal/inc/caching/ClasspathCache.scala | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala b/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala index 1010655bbc..65f4367f80 100644 --- a/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala +++ b/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala @@ -14,7 +14,7 @@ import java.lang.ref.{ Reference, SoftReference } import java.io.File import java.net.URLClassLoader import java.util.HashMap -import sbt.io.Milli.getModifiedTime +import sbt.io.IO.getModifiedTime // Hack for testing only final class ClassLoaderCache(val commonParent: ClassLoader) { diff --git a/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala b/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala index 5191c22fdd..cf1bef778b 100644 --- a/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala +++ b/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala @@ -15,7 +15,7 @@ import java.util.Optional import sbt.io.{ Hash => IOHash } import xsbti.compile.analysis.{ ReadStamps, Stamp } -import sbt.io.Milli.getModifiedTime +import sbt.io.IO.getModifiedTime import scala.collection.immutable.TreeMap import scala.util.matching.Regex diff --git a/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala b/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala index 71549fcf57..ef3ceef513 100644 --- a/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala +++ b/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala @@ -7,7 +7,7 @@ import java.nio.file.attribute.{ BasicFileAttributes, FileTime } import xsbti.compile.FileHash import sbt.internal.inc.{ EmptyStamp, Stamper } -import sbt.io.Milli.getModifiedTime +import sbt.io.IO.getModifiedTime object ClasspathCache { // For more safety, store both the time and size From 6cebf6e126310907fd7d8b4176735ab46b686c21 Mon Sep 17 00:00:00 2001 From: Dale Wijnand Date: Wed, 13 Dec 2017 16:11:45 +0000 Subject: [PATCH 3/4] Use IO.getModified over importing the method --- .../scala/sbt/internal/inc/classpath/ClassLoaderCache.scala | 4 ++-- .../zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala | 5 ++--- .../main/scala/sbt/internal/inc/caching/ClasspathCache.scala | 4 ++-- 3 files changed, 6 insertions(+), 7 deletions(-) diff --git a/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala b/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala index 65f4367f80..3bc90222be 100644 --- a/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala +++ b/internal/zinc-classpath/src/main/scala/sbt/internal/inc/classpath/ClassLoaderCache.scala @@ -14,7 +14,7 @@ import java.lang.ref.{ Reference, SoftReference } import java.io.File import java.net.URLClassLoader import java.util.HashMap -import sbt.io.IO.getModifiedTime +import sbt.io.IO // Hack for testing only final class ClassLoaderCache(val commonParent: ClassLoader) { @@ -44,7 +44,7 @@ final class ClassLoaderCache(val commonParent: ClassLoader) { mkLoader: () => ClassLoader ): ClassLoader = synchronized { - val tstamps = files.map(getModifiedTime) + val tstamps = files.map(IO.getModifiedTime) getFromReference(files, tstamps, delegate.get(files), mkLoader) } diff --git a/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala b/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala index cf1bef778b..ff518ad283 100644 --- a/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala +++ b/internal/zinc-core/src/main/scala/sbt/internal/inc/Stamp.scala @@ -13,9 +13,8 @@ import java.io.{ File, IOException } import java.util import java.util.Optional -import sbt.io.{ Hash => IOHash } +import sbt.io.{ Hash => IOHash, IO } import xsbti.compile.analysis.{ ReadStamps, Stamp } -import sbt.io.IO.getModifiedTime import scala.collection.immutable.TreeMap import scala.util.matching.Regex @@ -143,7 +142,7 @@ object Stamper { } val forHash = (toStamp: File) => tryStamp(Hash.ofFile(toStamp)) - val forLastModified = (toStamp: File) => tryStamp(new LastModified(getModifiedTime(toStamp))) + val forLastModified = (toStamp: File) => tryStamp(new LastModified(IO.getModifiedTime(toStamp))) } object Stamps { diff --git a/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala b/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala index ef3ceef513..c715d79bd3 100644 --- a/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala +++ b/zinc/src/main/scala/sbt/internal/inc/caching/ClasspathCache.scala @@ -7,7 +7,7 @@ import java.nio.file.attribute.{ BasicFileAttributes, FileTime } import xsbti.compile.FileHash import sbt.internal.inc.{ EmptyStamp, Stamper } -import sbt.io.IO.getModifiedTime +import sbt.io.IO object ClasspathCache { // For more safety, store both the time and size @@ -30,7 +30,7 @@ object ClasspathCache { val attrs = Files.readAttributes(file.toPath, classOf[BasicFileAttributes]) if (attrs.isDirectory) emptyFileHash(file) else { - val currentMetadata = (FileTime.fromMillis(getModifiedTime(file)), attrs.size()) + val currentMetadata = (FileTime.fromMillis(IO.getModifiedTime(file)), attrs.size()) Option(cacheMetadataJar.get(file)) match { case Some((metadata, hashHit)) if metadata == currentMetadata => hashHit case _ => genFileHash(file, currentMetadata) From 9784b87784346ac3e536e021c941aaf25a677356 Mon Sep 17 00:00:00 2001 From: Eugene Yokota Date: Fri, 15 Dec 2017 15:16:46 -0500 Subject: [PATCH 4/4] bump modules and plugins --- project/Dependencies.scala | 6 +++--- project/plugins.sbt | 7 ++----- 2 files changed, 5 insertions(+), 8 deletions(-) diff --git a/project/Dependencies.scala b/project/Dependencies.scala index 57eba55745..2d4e248d0a 100644 --- a/project/Dependencies.scala +++ b/project/Dependencies.scala @@ -7,9 +7,9 @@ object Dependencies { val scala212 = "2.12.4" val scala213 = "2.13.0-M2" - private val ioVersion = "1.1.1" - private val utilVersion = "1.1.0" - private val lmVersion = "1.0.4" + private val ioVersion = "1.1.2" + private val utilVersion = "1.1.1" + private val lmVersion = "1.1.1" private val sbtIO = "org.scala-sbt" %% "io" % ioVersion diff --git a/project/plugins.sbt b/project/plugins.sbt index c6926192a9..bf22074bf5 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -1,10 +1,7 @@ +addSbtPlugin("org.scala-sbt" % "sbt-houserules" % "0.3.4") +addSbtPlugin("org.scala-sbt" % "sbt-contraband" % "0.3.2") addSbtPlugin("pl.project13.scala" % "sbt-jmh" % "0.2.27") -addSbtPlugin("org.foundweekends" % "sbt-bintray" % "0.5.1") -addSbtPlugin("com.jsuereth" % "sbt-pgp" % "1.1.0-M1") addSbtPlugin("com.lucidchart" % "sbt-scalafmt" % "1.12") addSbtPlugin("de.heikoseeberger" % "sbt-header" % "3.0.2") -addSbtPlugin("org.scala-sbt" % "sbt-houserules" % "0.3.3") -addSbtPlugin("org.scala-sbt" % "sbt-contraband" % "0.3.0") addSbtPlugin("com.thesamet" % "sbt-protoc" % "0.99.12-rc5") libraryDependencies += "com.trueaccord.scalapb" %% "compilerplugin" % "0.6.0" -addSbtPlugin("com.typesafe" % "sbt-mima-plugin" % "0.1.17")