diff options
author | Christopher Vogt <oss.nsp@cvogt.org> | 2016-03-11 22:36:31 -0500 |
---|---|---|
committer | Christopher Vogt <oss.nsp@cvogt.org> | 2016-03-11 22:36:31 -0500 |
commit | 984a5f1f0f27d191695feeb3410968f2f35f8fc8 (patch) | |
tree | 56fd09257ebf8ff020fbb6a86c1ca529fa548da7 /stage1/MultiClassLoader.scala | |
parent | b408b441569dc165f4d41b048ff64253695a491d (diff) | |
download | cbt-984a5f1f0f27d191695feeb3410968f2f35f8fc8.tar.gz cbt-984a5f1f0f27d191695feeb3410968f2f35f8fc8.tar.bz2 cbt-984a5f1f0f27d191695feeb3410968f2f35f8fc8.zip |
Split ClassLoader classes into separate files and a few fixes
Diffstat (limited to 'stage1/MultiClassLoader.scala')
-rw-r--r-- | stage1/MultiClassLoader.scala | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/stage1/MultiClassLoader.scala b/stage1/MultiClassLoader.scala new file mode 100644 index 0000000..de9bd32 --- /dev/null +++ b/stage1/MultiClassLoader.scala @@ -0,0 +1,24 @@ +/* +package cbt +import java.net._ +import scala.util.Try + +import scala.collection.immutable.Seq + + +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(",") ++ ")" +} +*/ |