mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
compiler: more precise default error context for C errors
This commit is contained in:
parent
ea10f44fe6
commit
90996269fd
@ -8,6 +8,7 @@ import (
|
|||||||
time
|
time
|
||||||
filepath
|
filepath
|
||||||
v.pref
|
v.pref
|
||||||
|
term
|
||||||
)
|
)
|
||||||
|
|
||||||
fn todo() {
|
fn todo() {
|
||||||
@ -357,7 +358,9 @@ start:
|
|||||||
verror('C compiler error, while attempting to run: \n' + '-----------------------------------------------------------\n' + '$cmd\n' + '-----------------------------------------------------------\n' + 'Probably your C compiler is missing. \n' + 'Please reinstall it, or make it available in your PATH.\n\n' + missing_compiler_info())
|
verror('C compiler error, while attempting to run: \n' + '-----------------------------------------------------------\n' + '$cmd\n' + '-----------------------------------------------------------\n' + 'Probably your C compiler is missing. \n' + 'Please reinstall it, or make it available in your PATH.\n\n' + missing_compiler_info())
|
||||||
}
|
}
|
||||||
if v.pref.is_debug {
|
if v.pref.is_debug {
|
||||||
println(res.output)
|
eword := 'error:'
|
||||||
|
khighlight := if term.can_show_color_on_stdout() { term.red(eword) } else { eword }
|
||||||
|
println(res.output.replace(eword, khighlight))
|
||||||
verror("
|
verror("
|
||||||
==================
|
==================
|
||||||
C error. This should never happen.
|
C error. This should never happen.
|
||||||
@ -375,9 +378,11 @@ please put the whole output in a pastebin and contact us through the following w
|
|||||||
if res.output.len < 30 {
|
if res.output.len < 30 {
|
||||||
println(res.output)
|
println(res.output)
|
||||||
} else {
|
} else {
|
||||||
q := res.output.all_after('error: ').limit(150)
|
elines := error_context_lines( res.output, 'error:', 1, 12 )
|
||||||
println('==================')
|
println('==================')
|
||||||
println(q)
|
for eline in elines {
|
||||||
|
println(eline)
|
||||||
|
}
|
||||||
println('...')
|
println('...')
|
||||||
println('==================')
|
println('==================')
|
||||||
println('(Use `v -cg` to print the entire error message)\n')
|
println('(Use `v -cg` to print the entire error message)\n')
|
||||||
@ -554,3 +559,20 @@ fn missing_compiler_info() string {
|
|||||||
}
|
}
|
||||||
return ''
|
return ''
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn error_context_lines(text, keyword string, before, after int) []string {
|
||||||
|
khighlight := if term.can_show_color_on_stdout() { term.red(keyword) } else { keyword }
|
||||||
|
mut eline_idx := 0
|
||||||
|
mut lines := text.split_into_lines()
|
||||||
|
for idx, eline in lines {
|
||||||
|
if eline.contains(keyword) {
|
||||||
|
lines[idx] = lines[idx].replace(keyword, khighlight)
|
||||||
|
if eline_idx == 0 {
|
||||||
|
eline_idx = idx
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
idx_s := if eline_idx - before >= 0 { eline_idx - before } else { 0 }
|
||||||
|
idx_e := if idx_s + after < lines.len { idx_s + after } else { lines.len }
|
||||||
|
return lines[idx_s..idx_e]
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user