[Web] Highlight multiple tokens (datatype, number, string)
This commit is contained in:
parent
25a28bd8eb
commit
0588e1f2fe
@ -23,6 +23,7 @@ impl Printable for InlineCode {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn highlight(input: &String) -> String {
|
fn highlight(input: &String) -> String {
|
||||||
|
// The tokens come in order
|
||||||
let tokens = misti::tokenize(&input);
|
let tokens = misti::tokenize(&input);
|
||||||
|
|
||||||
if tokens.is_err() {
|
if tokens.is_err() {
|
||||||
@ -34,6 +35,9 @@ fn highlight(input: &String) -> String {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let mut output = input.clone();
|
let mut output = input.clone();
|
||||||
|
// Offset to the position of the tokens in the string, to allow
|
||||||
|
// several tokens to be highlighted
|
||||||
|
let mut offset = 0;
|
||||||
|
|
||||||
for token in tokens.unwrap() {
|
for token in tokens.unwrap() {
|
||||||
match &token.token_type {
|
match &token.token_type {
|
||||||
@ -41,9 +45,34 @@ fn highlight(input: &String) -> String {
|
|||||||
let start_pos = token.position;
|
let start_pos = token.position;
|
||||||
let end_pos = token.get_end_position();
|
let end_pos = token.get_end_position();
|
||||||
|
|
||||||
let range = start_pos..end_pos;
|
let range = (start_pos + offset)..(end_pos + offset);
|
||||||
let html = format!("<span class=\"token class-name\">{}</span>", token.value);
|
let html = format!("<span class=\"token class-name\">{}</span>", token.value);
|
||||||
|
|
||||||
|
// 38 is the number of extra characters added to the token
|
||||||
|
offset += 38;
|
||||||
|
|
||||||
|
output.replace_range(range, html.as_str());
|
||||||
|
}
|
||||||
|
TokenType::Number => {
|
||||||
|
let start_pos = token.position;
|
||||||
|
let end_pos = token.get_end_position();
|
||||||
|
|
||||||
|
let range = (start_pos + offset)..(end_pos + offset);
|
||||||
|
let html = format!("<span class=\"token number\">{}</span>", token.value);
|
||||||
|
|
||||||
|
offset += 34;
|
||||||
|
|
||||||
|
output.replace_range(range, html.as_str());
|
||||||
|
}
|
||||||
|
TokenType::String => {
|
||||||
|
let start_pos = token.position;
|
||||||
|
let end_pos = token.get_end_position();
|
||||||
|
|
||||||
|
let range = (start_pos + offset)..(end_pos + offset);
|
||||||
|
let html = format!("<span class=\"token string\">\"{}\"</span>", token.value);
|
||||||
|
|
||||||
|
offset += 34;
|
||||||
|
|
||||||
output.replace_range(range, html.as_str());
|
output.replace_range(range, html.as_str());
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {}
|
||||||
@ -69,4 +98,33 @@ mod tests {
|
|||||||
highlight(&String::from("Num"))
|
highlight(&String::from("Num"))
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn should_highlight_number() {
|
||||||
|
assert_eq!(
|
||||||
|
"<span class=\"token number\">322</span>",
|
||||||
|
highlight(&String::from("322"))
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn should_highlight_string() {
|
||||||
|
assert_eq!(
|
||||||
|
"<span class=\"token string\">\"Hello\"</span>",
|
||||||
|
highlight(&String::from("\"Hello\""))
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn should_highlight_multiple_tokens() {
|
||||||
|
assert_eq!(
|
||||||
|
"<span class=\"token class-name\">Str</span> x = <span class=\"token number\">322</span>",
|
||||||
|
highlight(&String::from("Str x = 322"))
|
||||||
|
);
|
||||||
|
|
||||||
|
assert_eq!(
|
||||||
|
"<span class=\"token class-name\">Str</span> x = <span class=\"token string\">\"hello\"</span> <span class=\"token number\">322</span>",
|
||||||
|
highlight(&String::from("Str x = \"hello\" 322"))
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user