From f587ec7c8f616d80f1a115fdb21a5b7f7da8ebf7 Mon Sep 17 00:00:00 2001 From: Lex Spoon Date: Tue, 12 Jun 2007 15:28:59 +0000 Subject: Replaced -Xscript by -script, so that script files can be compiled into a user-specified object wrapper --- src/compiler/scala/tools/nsc/CompilerCommand.scala | 2 +- src/compiler/scala/tools/nsc/Global.scala | 7 +-- src/compiler/scala/tools/nsc/ScriptRunner.scala | 57 ++++++++++++++++++---- src/compiler/scala/tools/nsc/Settings.scala | 2 +- 4 files changed, 53 insertions(+), 15 deletions(-) diff --git a/src/compiler/scala/tools/nsc/CompilerCommand.scala b/src/compiler/scala/tools/nsc/CompilerCommand.scala index eaafd7f6e0..22acb56a6b 100644 --- a/src/compiler/scala/tools/nsc/CompilerCommand.scala +++ b/src/compiler/scala/tools/nsc/CompilerCommand.scala @@ -80,7 +80,7 @@ class CompilerCommand(arguments: List[String], val settings: Settings, } else ok = settings.checkDependencies } - } else if (settings.Xscript.value || args.head.endsWith(fileEnding)) { + } else if ((settings.script.value != "") || args.head.endsWith(fileEnding)) { fs = args.head :: fs args = args.tail } else if (args.head.length == 0) {//quick fix diff --git a/src/compiler/scala/tools/nsc/Global.scala b/src/compiler/scala/tools/nsc/Global.scala index afedea0b1a..0c7e18c2e9 100644 --- a/src/compiler/scala/tools/nsc/Global.scala +++ b/src/compiler/scala/tools/nsc/Global.scala @@ -593,11 +593,12 @@ class Global(var settings: Settings, var reporter: Reporter) extends SymbolTable def compile(filenames: List[String]) { try { - if (settings.Xscript.value && filenames.length != 1) + val scriptMain = settings.script.value + if (scriptMain != "" && filenames.length != 1) error("can only compile one script at a time") val sources = filenames map ( - if (settings.Xscript.value) - (x => ScriptRunner.wrappedScript(x, getSourceFile _)) + if (scriptMain != "") + (x => ScriptRunner.wrappedScript(scriptMain, x, getSourceFile _)) else getSourceFile) compileSources(sources) diff --git a/src/compiler/scala/tools/nsc/ScriptRunner.scala b/src/compiler/scala/tools/nsc/ScriptRunner.scala index 2f0a0fdd4c..7afc0f5b5c 100644 --- a/src/compiler/scala/tools/nsc/ScriptRunner.scala +++ b/src/compiler/scala/tools/nsc/ScriptRunner.scala @@ -43,6 +43,15 @@ import scala.tools.nsc.util.{CompoundSourceFile, SourceFile, SourceFileFragment} * of stdout... */ object ScriptRunner { + /** Default name to use for the wrapped script */ + val defaultScriptMain = "Main" + + /** Pick a main object name from the specified settings */ + def scriptMain(settings: Settings) = + if (settings.script.value == "") + defaultScriptMain + else + settings.script.value /** Choose a jar filename to hold the compiled version * of a script @@ -127,18 +136,39 @@ object ScriptRunner { return matcher.end } + /** Split a fully qualified object name into a + * package and an unqualified object name */ + private def splitObjectName(fullname: String): + (Option[String],String) = + { + val idx = fullname.lastIndexOf('.') + if (idx < 0) + (None, fullname) + else + (Some(fullname.substring(0,idx)), fullname.substring(idx+1)) + } + + /** Wrap a script file into a runnable object named * scala.scripting.Main. - * - * @param filename ... - * @param getSourceFile ... - * @return ... */ - def wrappedScript(filename: String, getSourceFile: PlainFile => SourceFile): SourceFile = { + def wrappedScript( + objectName: String, + filename: String, + getSourceFile: PlainFile => SourceFile): SourceFile = + { + val (maybePack, objName) = splitObjectName(objectName) + + val packageDecl = + maybePack match { + case Some(pack) => "package " + pack + "\n" + case None => "" + } + val preamble = new SourceFile("