1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
use std::path::PathBuf;
use crate::impl_selectable_content;
/// A Vec of pathbuf of visited files.
/// It's mostly used as a stack but we want to avoid multiple instances of the
/// same path and visit in a certain order.
/// A `BTreeSet` may be used instead.
/// We also need to drop the queue, which isn't easy with a BTreeSet...
#[derive(Default, Clone)]
pub struct History {
/// The visited paths
pub content: Vec<PathBuf>,
/// The currently selected index. By default it's the last one.
pub index: usize,
}
impl History {
/// Add a new path in the stack, without duplicates, and select the last
/// one.
pub fn push(&mut self, path: &std::path::Path) {
let path = path.to_path_buf();
if !self.content.contains(&path) {
self.content.push(path);
self.index = self.len() - 1
}
}
/// Drop the last visited paths from the stack, after the selected one.
/// Used to go back a few steps in time.
pub fn drop_queue(&mut self) {
if self.is_empty() {
return;
}
let final_length = self.len() - self.index;
self.content.truncate(final_length);
if self.is_empty() {
self.index = 0
} else {
self.index = self.len() - 1
}
}
}
impl_selectable_content!(PathBuf, History);