From 18beda38ac9dfec843dcbb51adf596e294fc13b2 Mon Sep 17 00:00:00 2001 From: Gokul Soumya Date: Thu, 24 Jun 2021 21:24:34 +0530 Subject: Add … when chars are truncated in picker --- helix-tui/src/buffer.rs | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'helix-tui') diff --git a/helix-tui/src/buffer.rs b/helix-tui/src/buffer.rs index 0d1edc46..8b03cb0d 100644 --- a/helix-tui/src/buffer.rs +++ b/helix-tui/src/buffer.rs @@ -266,11 +266,30 @@ impl Buffer { width: usize, style: Style, ) -> (u16, u16) + where + S: AsRef, + { + self.set_string_truncated(x, y, string, width, style, false) + } + + /// Print at most the first `width` characters of a string if enough space is available + /// until the end of the line. If `markend` is true appends a `…` at the end of + /// truncated lines. + pub fn set_string_truncated( + &mut self, + x: u16, + y: u16, + string: S, + width: usize, + style: Style, + ellipsis: bool, + ) -> (u16, u16) where S: AsRef, { let mut index = self.index_of(x, y); let mut x_offset = x as usize; + let width = if ellipsis { width - 1 } else { width }; let graphemes = UnicodeSegmentation::graphemes(string.as_ref(), true); let max_offset = min(self.area.right() as usize, width.saturating_add(x as usize)); for s in graphemes { @@ -293,6 +312,9 @@ impl Buffer { index += width; x_offset += width; } + if ellipsis && x_offset - (x as usize) < string.as_ref().chars().count() { + self.content[index].set_symbol("…"); + } (x_offset as u16, y) } -- cgit v1.2.3-70-g09d2