compiler: print underlines in the same color as the error
parent
5f0ad0f562
commit
eabc72d4fe
|
@ -34,16 +34,30 @@ pub mut:
|
||||||
support_color bool
|
support_color bool
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn (e &EManager) set_support_color(b bool) {
|
|
||||||
e.support_color = b
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn new_error_manager() &EManager {
|
pub fn new_error_manager() &EManager {
|
||||||
return &EManager{
|
return &EManager{
|
||||||
support_color: term.can_show_color_on_stderr()
|
support_color: term.can_show_color_on_stderr()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn bold(msg string) string {
|
||||||
|
if !emanager.support_color {
|
||||||
|
return msg
|
||||||
|
}
|
||||||
|
return term.bold(msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn color(kind, msg string) string {
|
||||||
|
if !emanager.support_color {
|
||||||
|
return msg
|
||||||
|
}
|
||||||
|
if kind.contains('error') {
|
||||||
|
return term.red(msg)
|
||||||
|
} else {
|
||||||
|
return term.magenta(msg)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// formatted_error - `kind` may be 'error' or 'warn'
|
// formatted_error - `kind` may be 'error' or 'warn'
|
||||||
pub fn formatted_error(kind, emsg, filepath string, pos token.Position) string {
|
pub fn formatted_error(kind, emsg, filepath string, pos token.Position) string {
|
||||||
mut path := filepath
|
mut path := filepath
|
||||||
|
@ -72,16 +86,9 @@ pub fn formatted_error(kind, emsg, filepath string, pos token.Position) string {
|
||||||
column := imax(0, pos.pos - p - 1)
|
column := imax(0, pos.pos - p - 1)
|
||||||
position := '${path}:${pos.line_nr+1}:${util.imax(1,column+1)}:'
|
position := '${path}:${pos.line_nr+1}:${util.imax(1,column+1)}:'
|
||||||
scontext := source_context(kind, source, column, pos).join('\n')
|
scontext := source_context(kind, source, column, pos).join('\n')
|
||||||
final_position := if emanager.support_color { term.bold(position) } else { position }
|
final_position := bold(position)
|
||||||
mut final_kind := kind
|
final_kind := bold(color(kind, kind))
|
||||||
if emanager.support_color {
|
final_msg := emsg
|
||||||
final_kind = if kind.contains('error') {
|
|
||||||
term.bold(term.red(kind))
|
|
||||||
} else {
|
|
||||||
term.bold(term.magenta(kind))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
final_msg := emsg // if emanager.support_color { term.bold(emsg) } else { emsg }
|
|
||||||
final_context := if scontext.len > 0 { '\n$scontext' } else { '' }
|
final_context := if scontext.len > 0 { '\n$scontext' } else { '' }
|
||||||
//
|
//
|
||||||
return '$final_position $final_kind $final_msg $final_context'.trim_space()
|
return '$final_position $final_kind $final_msg $final_context'.trim_space()
|
||||||
|
@ -99,12 +106,8 @@ pub fn source_context(kind, source string, column int, pos token.Position) []str
|
||||||
for iline := bline; iline <= aline; iline++ {
|
for iline := bline; iline <= aline; iline++ {
|
||||||
sline := source_lines[iline]
|
sline := source_lines[iline]
|
||||||
mut cline := sline.replace('\t', tab_spaces)
|
mut cline := sline.replace('\t', tab_spaces)
|
||||||
if iline == pos.line_nr && emanager.support_color {
|
if iline == pos.line_nr {
|
||||||
cline = if kind.contains('error') {
|
cline = color(kind, cline)
|
||||||
term.red(cline)
|
|
||||||
} else {
|
|
||||||
term.magenta(cline)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
clines << '${iline+1:5d} | ' + cline
|
clines << '${iline+1:5d} | ' + cline
|
||||||
//
|
//
|
||||||
|
@ -131,19 +134,11 @@ pub fn source_context(kind, source string, column int, pos token.Position) []str
|
||||||
}
|
}
|
||||||
if pos.len > 1 {
|
if pos.len > 1 {
|
||||||
max_len := sline.len - pointerline.len // rest of the line
|
max_len := sline.len - pointerline.len // rest of the line
|
||||||
len := if pos.len > max_len { max_len } else { pos.len }
|
len := imin(max_len, pos.len)
|
||||||
underline := '~'.repeat(len)
|
underline := '~'.repeat(len)
|
||||||
pointerline << if emanager.support_color {
|
pointerline << bold(color(kind, underline))
|
||||||
term.bold(term.blue(underline))
|
|
||||||
} else {
|
|
||||||
underline
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
pointerline << if emanager.support_color {
|
pointerline << bold(color(kind, '^'))
|
||||||
term.bold(term.blue('^'))
|
|
||||||
} else {
|
|
||||||
'^'
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
@ -154,11 +149,8 @@ pub fn source_context(kind, source string, column int, pos token.Position) []str
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn verror(kind, s string) {
|
pub fn verror(kind, s string) {
|
||||||
if emanager.support_color {
|
final_kind := bold(color(kind, kind))
|
||||||
eprintln(term.bold(term.red(kind)) + ': $s')
|
eprintln('${final_kind}: $s')
|
||||||
} else {
|
|
||||||
eprintln('${kind}: $s')
|
|
||||||
}
|
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue