|
|
@@ -78,6 +78,8 @@ pub struct Render<'a> {
|
|
|
|
|
|
/// Whether we are skipping Git-ignored files.
|
|
|
pub git_ignoring: bool,
|
|
|
+
|
|
|
+ pub git: Option<&'a GitCache>,
|
|
|
}
|
|
|
|
|
|
impl<'a> Render<'a> {
|
|
|
@@ -98,6 +100,7 @@ impl<'a> Render<'a> {
|
|
|
recurse: None,
|
|
|
filter: self.filter,
|
|
|
git_ignoring: self.git_ignoring,
|
|
|
+ git: self.git,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -113,27 +116,28 @@ impl<'a> Render<'a> {
|
|
|
recurse: None,
|
|
|
filter: self.filter,
|
|
|
git_ignoring: self.git_ignoring,
|
|
|
+ git: self.git,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// This doesn’t take an IgnoreCache even though the details one does
|
|
|
// because grid-details has no tree view.
|
|
|
|
|
|
- pub fn render<W: Write>(self, git: Option<&GitCache>, w: &mut W) -> io::Result<()> {
|
|
|
- if let Some((grid, width)) = self.find_fitting_grid(git) {
|
|
|
+ pub fn render<W: Write>(mut self, w: &mut W) -> io::Result<()> {
|
|
|
+ if let Some((grid, width)) = self.find_fitting_grid() {
|
|
|
write!(w, "{}", grid.fit_into_columns(width))
|
|
|
}
|
|
|
else {
|
|
|
- self.give_up().render(git, w)
|
|
|
+ self.give_up().render(w)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- pub fn find_fitting_grid(&self, git: Option<&GitCache>) -> Option<(grid::Grid, grid::Width)> {
|
|
|
+ pub fn find_fitting_grid(&mut self) -> Option<(grid::Grid, grid::Width)> {
|
|
|
let options = self.details.table.as_ref().expect("Details table options not given!");
|
|
|
|
|
|
let drender = self.details();
|
|
|
|
|
|
- let (first_table, _) = self.make_table(options, git, &drender);
|
|
|
+ let (first_table, _) = self.make_table(options, &drender);
|
|
|
|
|
|
let rows = self.files.iter()
|
|
|
.map(|file| first_table.row_for_file(file, file_has_xattrs(file)))
|
|
|
@@ -154,12 +158,12 @@ impl<'a> Render<'a> {
|
|
|
})
|
|
|
.collect::<Vec<_>>();
|
|
|
|
|
|
- let mut last_working_table = self.make_grid(1, options, git, &file_names, rows.clone(), &drender);
|
|
|
+ let mut last_working_table = self.make_grid(1, options, &file_names, rows.clone(), &drender);
|
|
|
|
|
|
// If we can’t fit everything in a grid 100 columns wide, then
|
|
|
// something has gone seriously awry
|
|
|
for column_count in 2..100 {
|
|
|
- let grid = self.make_grid(column_count, options, git, &file_names, rows.clone(), &drender);
|
|
|
+ let grid = self.make_grid(column_count, options, &file_names, rows.clone(), &drender);
|
|
|
|
|
|
let the_grid_fits = {
|
|
|
let d = grid.fit_into_columns(column_count);
|
|
|
@@ -186,14 +190,14 @@ impl<'a> Render<'a> {
|
|
|
None
|
|
|
}
|
|
|
|
|
|
- fn make_table(&'a self, options: &'a TableOptions, mut git: Option<&'a GitCache>, drender: &DetailsRender) -> (Table<'a>, Vec<DetailsRow>) {
|
|
|
- match (git, self.dir) {
|
|
|
- (Some(g), Some(d)) => if ! g.has_anything_for(&d.path) { git = None },
|
|
|
- (Some(g), None) => if ! self.files.iter().any(|f| g.has_anything_for(&f.path)) { git = None },
|
|
|
+ fn make_table(&mut self, options: &'a TableOptions, drender: &DetailsRender) -> (Table<'a>, Vec<DetailsRow>) {
|
|
|
+ match (self.git, self.dir) {
|
|
|
+ (Some(g), Some(d)) => if ! g.has_anything_for(&d.path) { self.git = None },
|
|
|
+ (Some(g), None) => if ! self.files.iter().any(|f| g.has_anything_for(&f.path)) { self.git = None },
|
|
|
(None, _) => {/* Keep Git how it is */},
|
|
|
}
|
|
|
|
|
|
- let mut table = Table::new(options, git, self.colours);
|
|
|
+ let mut table = Table::new(options, self.git, self.colours);
|
|
|
let mut rows = Vec::new();
|
|
|
|
|
|
if self.details.header {
|
|
|
@@ -205,10 +209,10 @@ impl<'a> Render<'a> {
|
|
|
(table, rows)
|
|
|
}
|
|
|
|
|
|
- fn make_grid(&'a self, column_count: usize, options: &'a TableOptions, git: Option<&GitCache>, file_names: &[TextCell], rows: Vec<TableRow>, drender: &DetailsRender) -> grid::Grid {
|
|
|
+ fn make_grid(&mut self, column_count: usize, options: &'a TableOptions, file_names: &[TextCell], rows: Vec<TableRow>, drender: &DetailsRender) -> grid::Grid {
|
|
|
let mut tables = Vec::new();
|
|
|
for _ in 0 .. column_count {
|
|
|
- tables.push(self.make_table(options, git, drender));
|
|
|
+ tables.push(self.make_table(options, drender));
|
|
|
}
|
|
|
|
|
|
let mut num_cells = rows.len();
|