-
Notifications
You must be signed in to change notification settings - Fork 45
Fix display of annotation for double width characters #46
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
ac31f8a
29cfa73
bb47ac0
fbdab5c
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -550,3 +550,126 @@ fn test_i_29() { | |
|
||
assert_eq!(DisplayList::from(snippets).to_string(), expected); | ||
} | ||
|
||
#[test] | ||
fn test_point_to_double_width_characters() { | ||
let snippets = Snippet { | ||
slices: vec![snippet::Slice { | ||
source: "こんにちは、世界", | ||
line_start: 1, | ||
origin: Some("<current file>"), | ||
annotations: vec![snippet::SourceAnnotation { | ||
range: (6, 8), | ||
label: "world", | ||
annotation_type: snippet::AnnotationType::Error, | ||
}], | ||
fold: false, | ||
}], | ||
title: None, | ||
footer: vec![], | ||
opt: Default::default(), | ||
}; | ||
|
||
let expected = r#" --> <current file>:1:7 | ||
| | ||
1 | こんにちは、世界 | ||
| ^^^^ world | ||
|"#; | ||
Comment on lines
+573
to
+577
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
|
||
assert_eq!(DisplayList::from(snippets).to_string(), expected); | ||
} | ||
|
||
#[test] | ||
fn test_point_to_double_width_characters_across_lines() { | ||
let snippets = Snippet { | ||
slices: vec![snippet::Slice { | ||
source: "おはよう\nございます", | ||
line_start: 1, | ||
origin: Some("<current file>"), | ||
annotations: vec![snippet::SourceAnnotation { | ||
range: (2, 8), | ||
label: "Good morning", | ||
annotation_type: snippet::AnnotationType::Error, | ||
}], | ||
fold: false, | ||
}], | ||
title: None, | ||
footer: vec![], | ||
opt: Default::default(), | ||
}; | ||
|
||
let expected = r#" --> <current file>:1:3 | ||
| | ||
1 | おはよう | ||
| _____^ | ||
2 | | ございます | ||
| |______^ Good morning | ||
|"#; | ||
Comment on lines
+601
to
+607
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
|
||
assert_eq!(DisplayList::from(snippets).to_string(), expected); | ||
} | ||
|
||
#[test] | ||
fn test_point_to_double_width_characters_multiple() { | ||
let snippets = Snippet { | ||
slices: vec![snippet::Slice { | ||
source: "お寿司\n食べたい🍣", | ||
line_start: 1, | ||
origin: Some("<current file>"), | ||
annotations: vec![ | ||
snippet::SourceAnnotation { | ||
range: (0, 3), | ||
label: "Sushi1", | ||
annotation_type: snippet::AnnotationType::Error, | ||
}, | ||
snippet::SourceAnnotation { | ||
range: (6, 8), | ||
label: "Sushi2", | ||
annotation_type: snippet::AnnotationType::Note, | ||
}, | ||
], | ||
fold: false, | ||
}], | ||
title: None, | ||
footer: vec![], | ||
opt: Default::default(), | ||
}; | ||
|
||
let expected = r#" --> <current file>:1:1 | ||
| | ||
1 | お寿司 | ||
| ^^^^^^ Sushi1 | ||
2 | 食べたい🍣 | ||
| ---- note: Sushi2 | ||
|"#; | ||
Comment on lines
+638
to
+644
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. With monospace fonts, this is displayed like: |
||
|
||
assert_eq!(DisplayList::from(snippets).to_string(), expected); | ||
} | ||
|
||
#[test] | ||
fn test_point_to_double_width_characters_mixed() { | ||
let snippets = Snippet { | ||
slices: vec![snippet::Slice { | ||
source: "こんにちは、新しいWorld!", | ||
line_start: 1, | ||
origin: Some("<current file>"), | ||
annotations: vec![snippet::SourceAnnotation { | ||
range: (6, 14), | ||
label: "New world", | ||
annotation_type: snippet::AnnotationType::Error, | ||
}], | ||
fold: false, | ||
}], | ||
title: None, | ||
footer: vec![], | ||
opt: Default::default(), | ||
}; | ||
|
||
let expected = r#" --> <current file>:1:7 | ||
| | ||
1 | こんにちは、新しいWorld! | ||
| ^^^^^^^^^^^ New world | ||
|"#; | ||
Comment on lines
+668
to
+672
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
|
||
assert_eq!(DisplayList::from(snippets).to_string(), expected); | ||
} |