aboutsummaryrefslogtreecommitdiff
path: root/stage1/classloader.scala
blob: 3293dd12d675ba9a7409bbdd871317b6aa68509d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package cbt
import java.io._
import java.net._
import java.nio.file._
import scala.util.Try

import scala.collection.immutable.Seq

object ClassLoaderCache{
  private val cache = NailgunLauncher.classLoaderCache
  def classLoader( classpath: ClassPath, parent: ClassLoader )(implicit logger: Logger): ClassLoader
    = cache.synchronized{
    val lib = new Stage1Lib(logger)
    val key = classpath.strings.sorted.mkString(":")
    if( cache.containsKey(key) ){
      logger.resolver("CACHE HIT: "++key)
      cache.get(key)
    } else {
      logger.resolver("CACHE MISS: "++key)
      val cl = new cbt.URLClassLoader( classpath, parent )
      cache.put( key, cl )
      cl
    }
  }
  def remove( classpath: ClassPath ) = {
    val key = classpath.strings.sorted.mkString(":")
    cache.remove( key )
  }
}
/*
class MultiClassLoader(parents: Seq[ClassLoader]) extends ClassLoader {
  override def loadClass(name: String) = {
    //System.err.println("LOADING CLASS "++name);
    val c = parents.toStream.map{
      parent =>
      Try{
        parent.loadClass(name)
      }.map(Option[Class[_]](_)).recover{
        case _:ClassNotFoundException => None
      }.get
    }.find(_.isDefined).flatten
    c.getOrElse( ClassLoader.getSystemClassLoader.loadClass(name) )
  }
  override def toString = "MultiClassLoader(" ++ parents.mkString(",") ++ ")"
}
*/
case class URLClassLoader(classPath: ClassPath, parent: ClassLoader)
  extends java.net.URLClassLoader(
    classPath.strings.map(
      path => new URL("file:"++path)
    ).toArray,
    parent
  ){
  override def toString = (
    scala.Console.BLUE ++ "cbt.URLClassLoader" ++ scala.Console.RESET
      ++ "(\n  " ++ getURLs.map(_.toString).sorted.mkString(",\n  ")
      ++ (
        if(getParent() != ClassLoader.getSystemClassLoader())
          ",\n" ++ getParent().toString.split("\n").map("  "++_).mkString("\n")
        else ""
      )
      ++ "\n)"
  )
}