mirror of https://github.com/helix-editor/helix
Merge 275ef79f48
into 205e7ece70
commit
3f1b7b451b
|
@ -581,8 +581,13 @@ impl EditorView {
|
||||||
|
|
||||||
let mut x = viewport.x;
|
let mut x = viewport.x;
|
||||||
let current_doc = view!(editor).doc;
|
let current_doc = view!(editor).doc;
|
||||||
|
let mut current_doc_idx = None;
|
||||||
|
let mut needed_width = 0;
|
||||||
|
|
||||||
for doc in editor.documents() {
|
let entries: Vec<String> = editor
|
||||||
|
.documents()
|
||||||
|
.enumerate()
|
||||||
|
.map(|(idx, doc)| {
|
||||||
let fname = doc
|
let fname = doc
|
||||||
.path()
|
.path()
|
||||||
.unwrap_or(&scratch)
|
.unwrap_or(&scratch)
|
||||||
|
@ -591,21 +596,40 @@ impl EditorView {
|
||||||
.to_str()
|
.to_str()
|
||||||
.unwrap_or_default();
|
.unwrap_or_default();
|
||||||
|
|
||||||
let style = if current_doc == doc.id() {
|
let text = format!(" {}{} ", fname, if doc.is_modified() { "[+]" } else { "" });
|
||||||
|
|
||||||
|
if doc.id() == current_doc {
|
||||||
|
current_doc_idx = Some(idx);
|
||||||
|
needed_width += text.len();
|
||||||
|
} else if current_doc_idx.is_none() {
|
||||||
|
needed_width += text.len();
|
||||||
|
}
|
||||||
|
text
|
||||||
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
let mut to_trim = needed_width.saturating_sub(viewport.width as usize);
|
||||||
|
for (idx, filename) in entries.iter().enumerate() {
|
||||||
|
let mut text = filename.as_str();
|
||||||
|
if to_trim > 0 && to_trim < text.len() {
|
||||||
|
text = &filename[to_trim..];
|
||||||
|
to_trim = 0;
|
||||||
|
} else if to_trim > 0 {
|
||||||
|
to_trim -= text.len();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
let style = if idx == current_doc_idx.unwrap() {
|
||||||
bufferline_active
|
bufferline_active
|
||||||
} else {
|
} else {
|
||||||
bufferline_inactive
|
bufferline_inactive
|
||||||
};
|
};
|
||||||
|
|
||||||
let text = format!(" {}{} ", fname, if doc.is_modified() { "[+]" } else { "" });
|
let rem_width = viewport.right().saturating_sub(x);
|
||||||
let used_width = viewport.x.saturating_sub(x);
|
|
||||||
let rem_width = surface.area.width.saturating_sub(used_width);
|
|
||||||
|
|
||||||
x = surface
|
x = surface
|
||||||
.set_stringn(x, viewport.y, text, rem_width as usize, style)
|
.set_stringn(x, viewport.y, text, rem_width as usize, style)
|
||||||
.0;
|
.0;
|
||||||
|
|
||||||
if x >= surface.area.right() {
|
if x >= viewport.right() {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue