我正在尝试运行一个打包为JAR的Scala应用程序(包括依赖项),但在使用-Xbootclasspath/p
选项添加Scala库之前,这会失败。
调用失败:
java -jar /path/to/target/scala-2.10/application-assembly-1.0.jar
在应用程序执行了一些预期输出后,控制台显示:
线程“main”中的异常 scala.reflect.internal.MissingRequirementError:object scala.runtime 在编译器镜像中找不到。 在scala.reflect.internal.MissingRequirementError $ .signal(MissingRequirementError.scala:16) 在scala.reflect.internal.MissingRequirementError $ .notFound(MissingRequirementError.scala:17) 在scala.reflect.internal.Mirrors $ RootsBase.getModuleOrClass(Mirrors.scala:48) 在scala.reflect.internal.Mirrors $ RootsBase.getModuleOrClass(Mirrors.scala:40) 在scala.reflect.internal.Mirrors $ RootsBase.getModuleOrClass(Mirrors.scala:61) 在scala.reflect.internal.Mirrors $ RootsBase.getPackage(Mirrors.scala:172) 在scala.reflect.internal.Mirrors $ RootsBase.getRequiredPackage(Mirrors.scala:175) at scala.reflect.internal.Definitions $ DefinitionsClass.RuntimePackage $ lzycompute(Definitions.scala:181) at scala.reflect.internal.Definitions $ DefinitionsClass.RuntimePackage(Definitions.scala:181) at scala.reflect.internal.Definitions $ DefinitionsClass.RuntimePackageClass $ lzycompute(Definitions.scala:182) at scala.reflect.internal.Definitions $ DefinitionsClass.RuntimePackageClass(Definitions.scala:182) at scala.reflect.internal.Definitions $ DefinitionsClass.AnnotationDefaultAttr $ lzycompute(Definitions.scala:1015) 在scala.reflect.internal.Definitions $ DefinitionsClass.AnnotationDefaultAttr(Definitions.scala:1014) at scala.reflect.internal.Definitions $ DefinitionsClass.syntheticCoreClasses $ lzycompute(Definitions.scala:1144) at scala.reflect.internal.Definitions $ DefinitionsClass.syntheticCoreClasses(Definitions.scala:1143) at scala.reflect.internal.Definitions $ DefinitionsClass.symbolsNotPresentInBytecode $ lzycompute(Definitions.scala:1187) at scala.reflect.internal.Definitions $ DefinitionsClass.symbolsNotPresentInBytecode(Definitions.scala:1187) 在scala.reflect.internal.Definitions $ DefinitionsClass.init(Definitions.scala:1252) 在scala.tools.nsc.Global $ Run。(Global.scala:1290) 在extract.ScalaExtractor $ Compiler $ 2 $。(ScalaExtractor.scala:24)
工作调用:
java -Xbootclasspath/p:/path/to/home/.sbt/boot/scala-2.10.2/lib/scala-library.jar -jar /path/to/target/scala-2.10/application-assembly-1.0.jar
关于它的奇怪之处在于application-assembly-1.0.jar
已构建,因此它包含所有依赖项,包括Scala库。当提取JAR文件时,可以验证是否已包含scala.runtime
包中的类文件。
创建JAR文件
addSbtPlugin("com.eed3si9n" % "sbt-assembly" % "0.9.1")
已添加到project/plugins.sbt
,并且已调用assembly
目标。结果大约为25MB的JAR文件。
使用proguard构建JAR显示与程序集的JAR文件相同的运行时行为。
触发MissingRequirementError的应用程序代码
一些应用程序代码工作正常,并且一旦来自以下片段的new Run
执行,就会触发先前描述的异常。
import scala.reflect.internal.util.BatchSourceFile
import scala.reflect.io.AbstractFile
import scala.reflect.io.Path.jfile2path
import scala.tools.nsc.Global
import scala.tools.nsc.Settings
…
import scala.tools.nsc._
object Compiler extends Global(new Settings()) {
new Run // This is line 24 from the stack trace!
def parse(path: File) = {
val code = AbstractFile.getFile(path)
val bfs = new BatchSourceFile(code, code.toCharArray)
val parser = new syntaxAnalyzer.UnitParser(new CompilationUnit(bfs))
parser.smartParse()
}
}
val ast = Compiler.parse(file)
其中,scala-library
,scala-compiler
和scala-reflect
被定义为build.sbt
中的依赖项。
有关古玩/背景信息
该应用程序的目的是帮助Java和Scala程序的本地化。上面的代码片段的任务是从Scala文件中获取AST,以便在那里找到方法调用。
问题
-Xbootclasspath/p:scala-library.jar
调用JAR?scala.runtime
丢失了?答案 0 :(得分:10)
使用熟悉的按键配置设置的简便方法:
import scala.tools.nsc.Global
import scala.tools.nsc.Settings
def main(args: Array[String]) {
val s = new Settings
s processArgumentString "-usejavacp"
val g = new Global(s)
val r = new g.Run
}
适合您的情况。
更容易:
java -Dscala.usejavacp=true -jar ./scall.jar
奖金信息,我碰巧遇到the enabling commit message:
前进并实现类路径,如电子邮件中所述 关于理论的scala-internals,在这一点上我必须知道我是什么 做。
**公共服务公告**
如果您的代码停止使用此提交(大多数情况下) 可能错误就像“找不到对象标量”这样的错误 让它再次使用以下任何一个工作:
在命令行上传递-usejavacp
将系统属性“scala.usejavacp”设置为“true”
其中任何一个都会提醒scala你想要java应用程序 scala也将使用的类路径。