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
|
/* NSC -- new Scala compiler
* Copyright 2002-2013 LAMP/EPFL
* @author Martin Odersky
*/
package scala.tools.nsc
package reporters
import scala.reflect.internal.util._
/** Report information, warnings and errors.
*
* This describes the stable interface for issuing information, warnings and errors.
* The only abstract method in this class must be info0.
*/
abstract class Reporter {
protected def info0(pos: Position, msg: String, severity: Severity, force: Boolean): Unit
/** Informational messages. If `!force`, they may be suppressed. */
final def info(pos: Position, msg: String, force: Boolean): Unit = info0(pos, msg, INFO, force)
/** For sending a message which should not be labeled as a warning/error,
* but also shouldn't require -verbose to be visible.
*/
def echo(msg: String): Unit = info(NoPosition, msg, force = true)
def echo(pos: Position, msg: String): Unit = info(pos, msg, force = true)
/** Warnings and errors. */
def warning(pos: Position, msg: String): Unit = info0(pos, msg, WARNING, force = false)
def error(pos: Position, msg: String): Unit = info0(pos, msg, ERROR, force = false)
def flush(): Unit = { }
// overridden by sbt, IDE
def reset(): Unit = {
INFO.count = 0
WARNING.count = 0
ERROR.count = 0
cancelled = false
}
object severity extends Enumeration
class Severity(val id: Int) extends severity.Value {
var count: Int = 0
}
val INFO = new Severity(0) {
override def toString: String = "INFO"
}
val WARNING = new Severity(1) {
override def toString: String = "WARNING"
}
val ERROR = new Severity(2) {
override def toString: String = "ERROR"
}
private var incompleteHandler: (Position, String) => Unit = null
def incompleteHandled = incompleteHandler != null
def withIncompleteHandler[T](handler: (Position, String) => Unit)(thunk: => T) = {
val saved = incompleteHandler
incompleteHandler = handler
try thunk
finally incompleteHandler = saved
}
// used by sbt (via unit.cancel) to cancel a compile (see hasErrors)
var cancelled: Boolean = false
// overridden by sbt
def hasErrors: Boolean = ERROR.count > 0 || cancelled
// overridden by sbt
def hasWarnings: Boolean = WARNING.count > 0
// TODO
def incompleteInputError(pos: Position, msg: String): Unit = {
if (incompleteHandled) incompleteHandler(pos, msg)
else error(pos, msg)
}
// overridden by sbt, IDE -- should move out of this interface
// it's unrelated to reporting (IDE receives comments from ScaladocAnalyzer)
def comment(pos: Position, msg: String): Unit = {}
}
|