diff --git a/main/src/main/scala/sbt/internal/Load.scala b/main/src/main/scala/sbt/internal/Load.scala index 0d60029f4..e64cd1639 100755 --- a/main/src/main/scala/sbt/internal/Load.scala +++ b/main/src/main/scala/sbt/internal/Load.scala @@ -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" } }