blob: 9ad0bb2539dd0c36a98846053a11153860e89def (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
/* NSC -- new Scala compiler
* Copyright 2005-2007 LAMP/EPFL
* @author Martin Odersky
*/
// $Id$
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 */
lazy val fileEnding = Properties.fileEndingString
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 != "") ||
(fileEnding.split("\\|") exists (args.head.endsWith(_)))) {
fs = args.head :: fs
args = args.tail
} else if (args.head.length == 0) {//quick fix [martin: for what?]
args = args.tail
} else {
error("don't know what to do with " + args.head)
ok = false
}
}
ok &&= settings.checkDependencies
}
processArguments()
}
|