scala.tools.nsc.interpreter.AbstractOrMissingHandler.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scala-compiler Show documentation
Show all versions of scala-compiler Show documentation
Compiler for the Scala Programming Language
/* NSC -- new Scala compiler
* Copyright 2005-2013 LAMP/EPFL
* @author Paul Phillips
*/
package scala.tools.nsc
package interpreter
class AbstractOrMissingHandler[T](onError: String => Unit, value: T) extends PartialFunction[Throwable, T] {
def isDefinedAt(t: Throwable) = t match {
case _: AbstractMethodError => true
case _: NoSuchMethodError => true
case _: MissingRequirementError => true
case _: NoClassDefFoundError => true
case _ => false
}
def apply(t: Throwable) = t match {
case x @ (_: AbstractMethodError | _: NoSuchMethodError | _: NoClassDefFoundError) =>
onError("""
|Failed to initialize compiler: %s.
|This is most often remedied by a full clean and recompile.
|Otherwise, your classpath may continue bytecode compiled by
|different and incompatible versions of scala.
|""".stripMargin.format(x.getClass.getName split '.' last)
)
x.printStackTrace()
value
case x: MissingRequirementError =>
onError("""
|Failed to initialize compiler: %s not found.
|** Note that as of 2.8 scala does not assume use of the java classpath.
|** For the old behavior pass -usejavacp to scala, or if using a Settings
|** object programatically, settings.usejavacp.value = true.""".stripMargin.format(x.req)
)
value
}
}
object AbstractOrMissingHandler {
def apply[T]() = new AbstractOrMissingHandler[T](Console println _, null.asInstanceOf[T])
}