2021-10-11 19:20:57 +00:00
|
|
|
package prog8tests.helpers
|
|
|
|
|
2022-03-10 22:08:41 +00:00
|
|
|
import prog8.code.core.IErrorReporter
|
2022-03-11 19:35:25 +00:00
|
|
|
import prog8.code.core.Position
|
2021-10-11 19:20:57 +00:00
|
|
|
|
2023-12-28 12:48:01 +00:00
|
|
|
internal class ErrorReporterForTests(private val throwExceptionAtReportIfErrors: Boolean=true, private val keepMessagesAfterReporting: Boolean=false): IErrorReporter {
|
2021-10-11 19:20:57 +00:00
|
|
|
|
|
|
|
val errors = mutableListOf<String>()
|
|
|
|
val warnings = mutableListOf<String>()
|
2023-12-28 12:48:01 +00:00
|
|
|
val infos = mutableListOf<String>()
|
2021-10-11 19:20:57 +00:00
|
|
|
|
|
|
|
override fun err(msg: String, position: Position) {
|
2023-03-11 13:55:13 +00:00
|
|
|
val text = "${position.toClickableStr()} $msg"
|
|
|
|
if(text !in errors)
|
|
|
|
errors.add(text)
|
2021-10-11 19:20:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
override fun warn(msg: String, position: Position) {
|
2023-03-11 13:55:13 +00:00
|
|
|
val text = "${position.toClickableStr()} $msg"
|
|
|
|
if(text !in warnings)
|
|
|
|
warnings.add(text)
|
2021-10-11 19:20:57 +00:00
|
|
|
}
|
|
|
|
|
2023-12-28 12:48:01 +00:00
|
|
|
override fun info(msg: String, position: Position) {
|
|
|
|
val text = "${position.toClickableStr()} $msg"
|
|
|
|
if(text !in infos)
|
|
|
|
infos.add(text)
|
|
|
|
}
|
|
|
|
|
2023-06-25 13:19:51 +00:00
|
|
|
override fun undefined(symbol: List<String>, position: Position) {
|
|
|
|
err("undefined symbol: ${symbol.joinToString(".")}", position)
|
|
|
|
}
|
|
|
|
|
2021-10-11 19:20:57 +00:00
|
|
|
override fun noErrors(): Boolean = errors.isEmpty()
|
2024-02-04 22:41:01 +00:00
|
|
|
override fun noErrorForLine(position: Position) = !errors.any { ":${position.line}:" in it }
|
2021-10-11 19:20:57 +00:00
|
|
|
|
|
|
|
override fun report() {
|
2023-12-28 12:48:01 +00:00
|
|
|
infos.forEach { println("UNITTEST COMPILATION REPORT: INFO: $it") }
|
2021-10-31 23:24:15 +00:00
|
|
|
warnings.forEach { println("UNITTEST COMPILATION REPORT: WARNING: $it") }
|
|
|
|
errors.forEach { println("UNITTEST COMPILATION REPORT: ERROR: $it") }
|
2021-10-21 23:25:26 +00:00
|
|
|
if(throwExceptionAtReportIfErrors)
|
2023-12-28 12:48:01 +00:00
|
|
|
finalizeNumErrors(errors.size, warnings.size, infos.size)
|
2021-12-15 00:24:25 +00:00
|
|
|
if(!keepMessagesAfterReporting) {
|
|
|
|
clear()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fun clear() {
|
2021-10-11 19:20:57 +00:00
|
|
|
errors.clear()
|
|
|
|
warnings.clear()
|
2023-12-28 12:48:01 +00:00
|
|
|
infos.clear()
|
2021-10-11 19:20:57 +00:00
|
|
|
}
|
|
|
|
}
|