mirror of
https://github.com/ilyakooo0/helix.git
synced 2024-11-28 21:20:23 +03:00
simplify.
This commit is contained in:
parent
c70080dd68
commit
a924ad2885
@ -184,6 +184,7 @@ impl Selection {
|
|||||||
Self::single(pos, pos)
|
Self::single(pos, pos)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: consume an iterator or a vec to reduce allocations?
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub fn new(ranges: SmallVec<[Range; 1]>, primary_index: usize) -> Self {
|
pub fn new(ranges: SmallVec<[Range; 1]>, primary_index: usize) -> Self {
|
||||||
fn normalize(mut ranges: SmallVec<[Range; 1]>, mut primary_index: usize) -> Selection {
|
fn normalize(mut ranges: SmallVec<[Range; 1]>, mut primary_index: usize) -> Selection {
|
||||||
|
@ -69,15 +69,15 @@ impl EditorView {
|
|||||||
is_focused: bool,
|
is_focused: bool,
|
||||||
) {
|
) {
|
||||||
// TODO: inefficient, should feed chunks.iter() to tree_sitter.parse_with(|offset, pos|)
|
// TODO: inefficient, should feed chunks.iter() to tree_sitter.parse_with(|offset, pos|)
|
||||||
let source_code = view.doc.text().to_string();
|
let text = view.doc.text();
|
||||||
|
let source_code = text.to_string();
|
||||||
|
|
||||||
let last_line = view.last_line();
|
let last_line = view.last_line();
|
||||||
|
|
||||||
let range = {
|
let range = {
|
||||||
// calculate viewport byte ranges
|
// calculate viewport byte ranges
|
||||||
let start = view.doc.text().line_to_byte(view.first_line);
|
let start = text.line_to_byte(view.first_line);
|
||||||
let end = view.doc.text().line_to_byte(last_line)
|
let end = text.line_to_byte(last_line) + text.line(last_line).len_bytes();
|
||||||
+ view.doc.text().line(last_line).len_bytes();
|
|
||||||
|
|
||||||
start..end
|
start..end
|
||||||
};
|
};
|
||||||
@ -126,10 +126,12 @@ impl EditorView {
|
|||||||
HighlightEvent::Source { start, end } => {
|
HighlightEvent::Source { start, end } => {
|
||||||
// TODO: filter out spans out of viewport for now..
|
// TODO: filter out spans out of viewport for now..
|
||||||
|
|
||||||
let start = view.doc.text().byte_to_char(start);
|
// TODO: do these before iterating
|
||||||
let end = view.doc.text().byte_to_char(end); // <-- index 744, len 743
|
let text = view.doc.text();
|
||||||
|
let start = text.byte_to_char(start);
|
||||||
|
let end = text.byte_to_char(end);
|
||||||
|
|
||||||
let text = view.doc.text().slice(start..end);
|
let text = text.slice(start..end);
|
||||||
|
|
||||||
use helix_core::graphemes::{grapheme_width, RopeGraphemes};
|
use helix_core::graphemes::{grapheme_width, RopeGraphemes};
|
||||||
|
|
||||||
@ -141,6 +143,7 @@ impl EditorView {
|
|||||||
// TODO: we could render the text to a surface, then cache that, that
|
// TODO: we could render the text to a surface, then cache that, that
|
||||||
// way if only the selection/cursor changes we can copy from cache
|
// way if only the selection/cursor changes we can copy from cache
|
||||||
// and paint the new cursor.
|
// and paint the new cursor.
|
||||||
|
// We could keep a single resizable surface on the View for that.
|
||||||
|
|
||||||
let mut char_index = start;
|
let mut char_index = start;
|
||||||
|
|
||||||
@ -159,6 +162,13 @@ impl EditorView {
|
|||||||
} else if grapheme == "\t" {
|
} else if grapheme == "\t" {
|
||||||
visual_x += (TAB_WIDTH as u16);
|
visual_x += (TAB_WIDTH as u16);
|
||||||
} else {
|
} else {
|
||||||
|
if visual_x >= viewport.width {
|
||||||
|
// if we're offscreen just keep going until we hit a new line
|
||||||
|
// TODO: will need tweaking when we also take into account
|
||||||
|
// horizontal scrolling
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
// Cow will prevent allocations if span contained in a single slice
|
// Cow will prevent allocations if span contained in a single slice
|
||||||
// which should really be the majority case
|
// which should really be the majority case
|
||||||
let grapheme = Cow::from(grapheme);
|
let grapheme = Cow::from(grapheme);
|
||||||
@ -198,16 +208,12 @@ impl EditorView {
|
|||||||
|
|
||||||
// TODO: paint cursor heads except primary
|
// TODO: paint cursor heads except primary
|
||||||
|
|
||||||
// HAXX: we don't render the char if it's offscreen. This should be
|
surface.set_string(
|
||||||
// skipped in a better way much earlier
|
viewport.x + visual_x,
|
||||||
if visual_x < viewport.width {
|
viewport.y + line,
|
||||||
surface.set_string(
|
grapheme,
|
||||||
viewport.x + visual_x,
|
style,
|
||||||
viewport.y + line,
|
);
|
||||||
grapheme,
|
|
||||||
style,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
visual_x += width;
|
visual_x += width;
|
||||||
}
|
}
|
||||||
|
@ -57,6 +57,12 @@ impl Container {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Default for Container {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self::new()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Tree {
|
impl Tree {
|
||||||
pub fn new(area: Rect) -> Self {
|
pub fn new(area: Rect) -> Self {
|
||||||
let root = Node::container();
|
let root = Node::container();
|
||||||
|
Loading…
Reference in New Issue
Block a user