2022-04-06 21:41:51 +00:00
|
|
|
use gpui::ViewContext;
|
|
|
|
use util::test::{marked_text, marked_text_ranges};
|
2022-03-22 17:55:03 +00:00
|
|
|
|
2022-03-26 01:09:37 +00:00
|
|
|
use crate::{
|
|
|
|
display_map::{DisplayMap, DisplaySnapshot, ToDisplayPoint},
|
2022-04-06 21:41:51 +00:00
|
|
|
DisplayPoint, Editor, MultiBuffer,
|
2022-03-26 01:09:37 +00:00
|
|
|
};
|
|
|
|
|
2021-11-12 16:01:57 +00:00
|
|
|
#[cfg(test)]
|
|
|
|
#[ctor::ctor]
|
|
|
|
fn init_logger() {
|
2022-02-07 23:00:00 +00:00
|
|
|
if std::env::var("RUST_LOG").is_ok() {
|
|
|
|
env_logger::init();
|
|
|
|
}
|
2021-11-12 16:01:57 +00:00
|
|
|
}
|
2022-03-22 17:55:03 +00:00
|
|
|
|
2022-03-26 01:09:37 +00:00
|
|
|
// Returns a snapshot from text containing '|' character markers with the markers removed, and DisplayPoints for each one.
|
|
|
|
pub fn marked_display_snapshot(
|
|
|
|
text: &str,
|
|
|
|
cx: &mut gpui::MutableAppContext,
|
|
|
|
) -> (DisplaySnapshot, Vec<DisplayPoint>) {
|
|
|
|
let (unmarked_text, markers) = marked_text(text);
|
|
|
|
|
|
|
|
let family_id = cx.font_cache().load_family(&["Helvetica"]).unwrap();
|
|
|
|
let font_id = cx
|
|
|
|
.font_cache()
|
|
|
|
.select_font(family_id, &Default::default())
|
|
|
|
.unwrap();
|
|
|
|
let font_size = 14.0;
|
|
|
|
|
|
|
|
let buffer = MultiBuffer::build_simple(&unmarked_text, cx);
|
|
|
|
let display_map =
|
2022-04-06 17:20:57 +00:00
|
|
|
cx.add_model(|cx| DisplayMap::new(buffer, font_id, font_size, None, 1, 1, cx));
|
2022-03-26 01:09:37 +00:00
|
|
|
let snapshot = display_map.update(cx, |map, cx| map.snapshot(cx));
|
|
|
|
let markers = markers
|
|
|
|
.into_iter()
|
|
|
|
.map(|offset| offset.to_display_point(&snapshot))
|
|
|
|
.collect();
|
|
|
|
|
|
|
|
(snapshot, markers)
|
|
|
|
}
|
2022-04-06 21:41:51 +00:00
|
|
|
|
|
|
|
pub fn select_ranges(editor: &mut Editor, marked_text: &str, cx: &mut ViewContext<Editor>) {
|
|
|
|
let (umarked_text, text_ranges) = marked_text_ranges(marked_text);
|
|
|
|
assert_eq!(editor.text(cx), umarked_text);
|
2022-05-12 21:18:46 +00:00
|
|
|
editor.change_selections(None, cx, |s| s.select_ranges(text_ranges));
|
2022-04-06 21:41:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn assert_text_with_selections(
|
|
|
|
editor: &mut Editor,
|
|
|
|
marked_text: &str,
|
|
|
|
cx: &mut ViewContext<Editor>,
|
|
|
|
) {
|
|
|
|
let (unmarked_text, text_ranges) = marked_text_ranges(marked_text);
|
|
|
|
|
|
|
|
assert_eq!(editor.text(cx), unmarked_text);
|
2022-05-12 22:55:18 +00:00
|
|
|
assert_eq!(editor.selections.selected_ranges(cx), text_ranges);
|
2022-04-06 21:41:51 +00:00
|
|
|
}
|