Use parent's toString

This commit is contained in:
Eugene Yokota 2016-05-25 12:57:38 -04:00
parent dc71b171da
commit 88a644eb4d
1 changed files with 9 additions and 10 deletions

View File

@ -943,21 +943,20 @@ private[sbt] object Load {
final class EvaluatedConfigurations(val eval: Eval, val settings: Seq[Setting[_]])
final case class InjectSettings(global: Seq[Setting[_]], project: Seq[Setting[_]], projectLoaded: ClassLoader => Seq[Setting[_]]) {
import java.net.URLClassLoader
private val cache: mutable.Map[List[URL], Seq[Setting[_]]] = mutable.Map.empty
private val cache: mutable.Map[String, Seq[Setting[_]]] = mutable.Map.empty
// Cache based on the underlying URL values of the classloader
def cachedProjectLoaded(cl: ClassLoader): Seq[Setting[_]] =
cl match {
case cl: URLClassLoader => cache.getOrElseUpdate(classLoaderToList(cl), projectLoaded(cl))
case cl: URLClassLoader => cache.getOrElseUpdate(classLoaderToHash(Some(cl)), projectLoaded(cl))
case _ => projectLoaded(cl)
}
private def classLoaderToList(cl: ClassLoader): List[URL] =
cl match {
case cl: URLClassLoader =>
cl.getURLs.toList ::: (Option(cl.getParent) match {
case Some(x) => classLoaderToList(x)
case _ => Nil
})
case _ => Nil
private def classLoaderToHash(o: Option[ClassLoader]): String =
o match {
case Some(cl: URLClassLoader) =>
cl.getURLs.toList.toString + classLoaderToHash(Option(cl.getParent))
case Some(cl: ClassLoader) =>
cl.toString + classLoaderToHash(Option(cl.getParent))
case _ => "null"
}
}