compilercommand.scala
来自「JAVA 语言的函数式编程扩展」· SCALA 代码 · 共 110 行
SCALA
110 行
/* NSC -- new Scala compiler * Copyright 2005-2007 LAMP/EPFL * @author Martin Odersky */// $Id: CompilerCommand.scala 14270 2008-03-05 15:07:14Z washburn $package scala.tools.nsc/** A class representing command line info for scalac */class CompilerCommand(arguments: List[String], val settings: Settings, error: String => Unit, interactive: Boolean) { private var fs: List[String] = List() /** All files to compile */ def files: List[String] = fs.reverse /** The name of the command */ val cmdName = "scalac" /** The file extension of files that the compiler can process */ def fileEnding = Properties.fileEndingString //todo: lazy val private val helpSyntaxColumnWidth: Int = Iterable.max(settings.allSettings map (_.helpSyntax.length)) private def format(s: String): String = { val buf = new StringBuilder(s) var i = s.length while (i < helpSyntaxColumnWidth) { buf.append(' '); i += 1 } buf.toString() } /** A message explaining usage and options */ def usageMsg: String = { settings.allSettings .filter(_.isStandard) .map(setting => format(setting.helpSyntax) + " " + setting.helpDescription) .mkString("Usage: " + cmdName + " <options> <source files>\n" + "where possible standard options include:\n ", "\n ", "\n") } /** A message explaining usage and options */ def xusageMsg: String = { settings.allSettings .filter(_.isAdvanced) .map(setting => format(setting.helpSyntax) + " " + setting.helpDescription) .mkString("Possible advanced options include:\n ", "\n ", "\n") } /** A message explaining usage and options */ def yusageMsg: String = { settings.allSettings .filter(_.isPrivate) .map(setting => format(setting.helpSyntax) + " " + setting.helpDescription) .mkString("Possible private options include:\n ", "\n ", "\n") } /** Whether the command was processed okay */ var ok = true /** Process the arguments and update the settings accordingly. This method is called only once, during initialization. */ protected def processArguments() { // initialization var args = arguments while (!args.isEmpty && ok) { if (args.head startsWith "-") { if (interactive) { error("no options can be given in interactive mode") ok = false } else { val args0 = args for (setting <- settings.allSettings) if (args eq args0) args = setting.tryToSet(args) if (args eq args0) { error("bad option: '" + args.head + "'") ok = false } } } else if ((settings.script.value != "") || args.head.endsWith(fileEnding)) { fs = args.head :: fs args = args.tail } else if (args.head.length == 0) {//quick fix args = args.tail } else { error("don't know what to do with " + args.head) ok = false } } ok &&= settings.checkDependencies } processArguments()}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?