all: add limit to accumulated errors / warnings (#11183)

pull/11184/head
Leo Developer 2021-08-14 18:49:21 +02:00 committed by GitHub
parent deb26b92b9
commit 8a8a0932f7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 49 additions and 26 deletions

View File

@ -131,6 +131,7 @@ const (
'-w', '-w',
'-print-v-files', '-print-v-files',
'-error-limit', '-error-limit',
'-warn-error-limit',
'-os', '-os',
'-printfn', '-printfn',
'-cflags', '-cflags',

View File

@ -82,6 +82,10 @@ NB: the build flags are shared with the run command too:
d) the function name d) the function name
NB: if you want to output the profile info to stdout, use `-profile -`. NB: if you want to output the profile info to stdout, use `-profile -`.
-warn-error-limit <limit>
Limit of warnings / errors that will be accumulated (defaults to 100).
Settings this to a negative value will disable the limit.
-profile-no-inline -profile-no-inline
Skip [inline] functions when profiling. Skip [inline] functions when profiling.

View File

@ -7622,6 +7622,9 @@ fn (mut c Checker) warn_or_error(message string, pos token.Position, warn bool)
} }
if warn && !c.pref.skip_warnings { if warn && !c.pref.skip_warnings {
c.nr_warnings++ c.nr_warnings++
if c.nr_warnings >= c.pref.warn_error_limit && c.pref.warn_error_limit >= 0 {
return
}
wrn := errors.Warning{ wrn := errors.Warning{
reporter: errors.Reporter.checker reporter: errors.Reporter.checker
pos: pos pos: pos
@ -7638,6 +7641,7 @@ fn (mut c Checker) warn_or_error(message string, pos token.Position, warn bool)
exit(1) exit(1)
} }
c.nr_errors++ c.nr_errors++
if c.nr_errors < c.pref.warn_error_limit || c.pref.warn_error_limit < 0 {
if pos.line_nr !in c.error_lines { if pos.line_nr !in c.error_lines {
err := errors.Error{ err := errors.Error{
reporter: errors.Reporter.checker reporter: errors.Reporter.checker
@ -7651,6 +7655,7 @@ fn (mut c Checker) warn_or_error(message string, pos token.Position, warn bool)
c.error_lines << pos.line_nr c.error_lines << pos.line_nr
} }
} }
}
} }
// for debugging only // for debugging only

View File

@ -1649,8 +1649,10 @@ pub fn (mut p Parser) error_with_error(error errors.Error) {
eprintln(ferror) eprintln(ferror)
exit(1) exit(1)
} else { } else {
if p.errors.len < p.pref.warn_error_limit || p.pref.warn_error_limit < 0 {
p.errors << error p.errors << error
} }
}
if p.pref.output_mode == .silent { if p.pref.output_mode == .silent {
// Normally, parser errors mean that the parser exits immediately, so there can be only 1 parser error. // Normally, parser errors mean that the parser exits immediately, so there can be only 1 parser error.
// In the silent mode however, the parser continues to run, even though it would have stopped. Some // In the silent mode however, the parser continues to run, even though it would have stopped. Some
@ -1672,6 +1674,7 @@ pub fn (mut p Parser) warn_with_pos(s string, pos token.Position) {
ferror := util.formatted_error('warning:', s, p.file_name, pos) ferror := util.formatted_error('warning:', s, p.file_name, pos)
eprintln(ferror) eprintln(ferror)
} else { } else {
if p.warnings.len < p.pref.warn_error_limit || p.pref.warn_error_limit < 0 {
p.warnings << errors.Warning{ p.warnings << errors.Warning{
file_path: p.file_name file_path: p.file_name
pos: pos pos: pos
@ -1679,6 +1682,7 @@ pub fn (mut p Parser) warn_with_pos(s string, pos token.Position) {
message: s message: s
} }
} }
}
} }
pub fn (mut p Parser) note_with_pos(s string, pos token.Position) { pub fn (mut p Parser) note_with_pos(s string, pos token.Position) {

View File

@ -189,6 +189,7 @@ pub mut:
gc_mode GarbageCollectionMode = .no_gc // .no_gc, .boehm, .boehm_leak, ... gc_mode GarbageCollectionMode = .no_gc // .no_gc, .boehm, .boehm_leak, ...
is_cstrict bool // turn on more C warnings; slightly slower is_cstrict bool // turn on more C warnings; slightly slower
assert_failure_mode AssertFailureMode // whether to call abort() or print_backtrace() after an assertion failure assert_failure_mode AssertFailureMode // whether to call abort() or print_backtrace() after an assertion failure
warn_error_limit int = 100 // limit of warnings/errors to be accumulated
// checker settings: // checker settings:
checker_match_exhaustive_cutoff_limit int = 12 checker_match_exhaustive_cutoff_limit int = 12
} }
@ -519,6 +520,10 @@ pub fn parse_args(known_external_commands []string, args []string) (&Preferences
} }
i++ i++
} }
'-warn-error-limit' {
res.warn_error_limit = cmdline.option(current_args, arg, '10').int()
i++
}
'-cc' { '-cc' {
res.ccompiler = cmdline.option(current_args, '-cc', 'cc') res.ccompiler = cmdline.option(current_args, '-cc', 'cc')
res.build_options << '$arg "$res.ccompiler"' res.build_options << '$arg "$res.ccompiler"'

View File

@ -1354,6 +1354,7 @@ pub fn (mut s Scanner) warn(msg string) {
if s.pref.output_mode == .stdout { if s.pref.output_mode == .stdout {
eprintln(util.formatted_error('warning:', msg, s.file_path, pos)) eprintln(util.formatted_error('warning:', msg, s.file_path, pos))
} else { } else {
if s.warnings.len < s.pref.warn_error_limit || s.pref.warn_error_limit < 0 {
s.warnings << errors.Warning{ s.warnings << errors.Warning{
file_path: s.file_path file_path: s.file_path
pos: pos pos: pos
@ -1361,6 +1362,7 @@ pub fn (mut s Scanner) warn(msg string) {
message: msg message: msg
} }
} }
}
} }
pub fn (mut s Scanner) error(msg string) { pub fn (mut s Scanner) error(msg string) {
@ -1376,6 +1378,7 @@ pub fn (mut s Scanner) error(msg string) {
if s.pref.fatal_errors { if s.pref.fatal_errors {
exit(1) exit(1)
} }
if s.errors.len < s.pref.warn_error_limit || s.pref.warn_error_limit < 0 {
s.errors << errors.Error{ s.errors << errors.Error{
file_path: s.file_path file_path: s.file_path
pos: pos pos: pos
@ -1383,6 +1386,7 @@ pub fn (mut s Scanner) error(msg string) {
message: msg message: msg
} }
} }
}
} }
fn (mut s Scanner) vet_error(msg string, fix vet.FixKind) { fn (mut s Scanner) vet_error(msg string, fix vet.FixKind) {