vdoc: improve syntax highlighting (#9323)
parent
0547a0a9cd
commit
0b0e96a8cd
|
@ -89,6 +89,9 @@ enum HighlightTokenTyp {
|
||||||
punctuation
|
punctuation
|
||||||
string
|
string
|
||||||
symbol
|
symbol
|
||||||
|
none_
|
||||||
|
module_
|
||||||
|
prefix
|
||||||
}
|
}
|
||||||
|
|
||||||
struct SearchModuleResult {
|
struct SearchModuleResult {
|
||||||
|
|
|
@ -160,9 +160,18 @@ fn color_highlight(code string, tb &table.Table) string {
|
||||||
.function {
|
.function {
|
||||||
term.cyan(tok.lit)
|
term.cyan(tok.lit)
|
||||||
}
|
}
|
||||||
.number {
|
.number, .module_ {
|
||||||
term.bright_blue(tok.lit)
|
term.bright_blue(tok.lit)
|
||||||
}
|
}
|
||||||
|
.boolean {
|
||||||
|
term.bright_magenta(tok.lit)
|
||||||
|
}
|
||||||
|
.none_ {
|
||||||
|
term.red(tok.lit)
|
||||||
|
}
|
||||||
|
.prefix {
|
||||||
|
term.magenta(tok.lit)
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
tok.lit
|
tok.lit
|
||||||
}
|
}
|
||||||
|
@ -170,6 +179,7 @@ fn color_highlight(code string, tb &table.Table) string {
|
||||||
return lit
|
return lit
|
||||||
}
|
}
|
||||||
mut s := scanner.new_scanner(code, .parse_comments, &pref.Preferences{})
|
mut s := scanner.new_scanner(code, .parse_comments, &pref.Preferences{})
|
||||||
|
mut prev_prev := token.Token{}
|
||||||
mut prev := token.Token{}
|
mut prev := token.Token{}
|
||||||
mut tok := s.scan()
|
mut tok := s.scan()
|
||||||
mut next_tok := s.scan()
|
mut next_tok := s.scan()
|
||||||
|
@ -181,13 +191,23 @@ fn color_highlight(code string, tb &table.Table) string {
|
||||||
match tok.kind {
|
match tok.kind {
|
||||||
.name {
|
.name {
|
||||||
if (tok.lit in builtin || tb.known_type(tok.lit))
|
if (tok.lit in builtin || tb.known_type(tok.lit))
|
||||||
&& (next_tok.kind != .lpar || prev.kind != .key_fn) {
|
&& (next_tok.kind != .lpar || prev.kind !in [.key_fn, .rpar]) {
|
||||||
tok_typ = .builtin
|
tok_typ = .builtin
|
||||||
} else if next_tok.kind in [.lcbr, .rpar, .eof]
|
} else if
|
||||||
&& (next_tok.kind != .rpar || prev.kind in [.name, .amp]) {
|
next_tok.kind in [.lcbr, .rpar, .eof, .comma, .pipe, .name, .rcbr, .assign, .key_pub, .key_mut, .pipe, .comma]
|
||||||
|
&& prev.kind in [.name, .amp, .rsbr, .key_type, .assign, .dot, .question, .rpar, .key_struct, .key_enum, .pipe, .key_interface]
|
||||||
|
&& (tok.lit[0].ascii_str().is_upper() || prev_prev.lit in ['C', 'JS']) {
|
||||||
tok_typ = .symbol
|
tok_typ = .symbol
|
||||||
} else if next_tok.kind in [.lpar, .lt] {
|
} else if next_tok.kind in [.lpar, .lt] {
|
||||||
tok_typ = .function
|
tok_typ = .function
|
||||||
|
} else if next_tok.kind == .dot {
|
||||||
|
if tok.lit in ['C', 'JS'] {
|
||||||
|
tok_typ = .prefix
|
||||||
|
} else {
|
||||||
|
tok_typ = .module_
|
||||||
|
}
|
||||||
|
} else if tok.lit in ['r', 'c'] && next_tok.kind == .string {
|
||||||
|
tok_typ = .prefix
|
||||||
} else {
|
} else {
|
||||||
tok_typ = .name
|
tok_typ = .name
|
||||||
}
|
}
|
||||||
|
@ -210,6 +230,9 @@ fn color_highlight(code string, tb &table.Table) string {
|
||||||
.lpar, .lcbr, .rpar, .rcbr, .lsbr, .rsbr, .semicolon, .colon, .comma, .dot {
|
.lpar, .lcbr, .rpar, .rcbr, .lsbr, .rsbr, .semicolon, .colon, .comma, .dot {
|
||||||
tok_typ = .punctuation
|
tok_typ = .punctuation
|
||||||
}
|
}
|
||||||
|
.key_none {
|
||||||
|
tok_typ = .none_
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
if token.is_key(tok.lit) || token.is_decl(tok.kind) {
|
if token.is_key(tok.lit) || token.is_decl(tok.kind) {
|
||||||
tok_typ = .keyword
|
tok_typ = .keyword
|
||||||
|
@ -220,18 +243,20 @@ fn color_highlight(code string, tb &table.Table) string {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
buf.write_string(highlight_code(tok, tok_typ))
|
buf.write_string(highlight_code(tok, tok_typ))
|
||||||
if prev.kind != .eof {
|
if prev_prev.kind == .eof {
|
||||||
prev = tok
|
break
|
||||||
} else {
|
}
|
||||||
|
prev_prev = prev
|
||||||
|
if prev.kind == .eof {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
prev = tok
|
||||||
|
if next_tok.kind == .eof {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
if next_tok.kind != .eof {
|
|
||||||
i = tok.pos + tok.len
|
i = tok.pos + tok.len
|
||||||
tok = next_tok
|
tok = next_tok
|
||||||
next_tok = s.scan()
|
next_tok = s.scan()
|
||||||
} else {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
buf.write_b(code[i])
|
buf.write_b(code[i])
|
||||||
i++
|
i++
|
||||||
|
|
Loading…
Reference in New Issue