mirror of
https://github.com/Llewellynvdm/exa.git
synced 2025-04-04 22:41:51 +00:00
Don’t pass Dirs to the Table
A Table now doesn’t need to know about (or even import) Dir, because we can just not pass the Git reference in if it shouldn’t be using it.
This commit is contained in:
parent
f3c7fa500f
commit
558b13880b
@ -140,11 +140,12 @@ impl<'a> AsRef<File<'a>> for Egg<'a> {
|
|||||||
|
|
||||||
|
|
||||||
impl<'a> Render<'a> {
|
impl<'a> Render<'a> {
|
||||||
pub fn render<W: Write>(self, git: Option<&'a GitCache>, w: &mut W) -> IOResult<()> {
|
pub fn render<W: Write>(self, mut git: Option<&'a GitCache>, w: &mut W) -> IOResult<()> {
|
||||||
let mut rows = Vec::new();
|
let mut rows = Vec::new();
|
||||||
|
|
||||||
if let Some(ref table) = self.opts.table {
|
if let Some(ref table) = self.opts.table {
|
||||||
let mut table = Table::new(&table, self.dir, git, &self.colours);
|
if self.dir.is_none() { git = None }
|
||||||
|
let mut table = Table::new(&table, git, &self.colours);
|
||||||
|
|
||||||
if self.opts.header {
|
if self.opts.header {
|
||||||
let header = table.header_row();
|
let header = table.header_row();
|
||||||
|
@ -167,8 +167,9 @@ impl<'a> Render<'a> {
|
|||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
fn make_table<'t>(&'a self, options: &'a TableOptions, git: Option<&'a GitCache>, drender: &DetailsRender) -> (Table<'a>, Vec<DetailsRow>) {
|
fn make_table<'t>(&'a self, options: &'a TableOptions, mut git: Option<&'a GitCache>, drender: &DetailsRender) -> (Table<'a>, Vec<DetailsRow>) {
|
||||||
let mut table = Table::new(options, self.dir, git, self.colours);
|
if self.dir.is_none() { git = None }
|
||||||
|
let mut table = Table::new(options, git, self.colours);
|
||||||
let mut rows = Vec::new();
|
let mut rows = Vec::new();
|
||||||
|
|
||||||
if self.details.header {
|
if self.details.header {
|
||||||
|
@ -13,7 +13,7 @@ use users::UsersCache;
|
|||||||
use style::Colours;
|
use style::Colours;
|
||||||
use output::cell::TextCell;
|
use output::cell::TextCell;
|
||||||
use output::time::TimeFormat;
|
use output::time::TimeFormat;
|
||||||
use fs::{File, Dir, fields as f};
|
use fs::{File, fields as f};
|
||||||
use fs::feature::git::GitCache;
|
use fs::feature::git::GitCache;
|
||||||
|
|
||||||
|
|
||||||
@ -284,9 +284,8 @@ pub struct Row {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'f> Table<'a> {
|
impl<'a, 'f> Table<'a> {
|
||||||
pub fn new(options: &'a Options, dir: Option<&'a Dir>, git: Option<&'a GitCache>, colours: &'a Colours) -> Table<'a> {
|
pub fn new(options: &'a Options, git: Option<&'a GitCache>, colours: &'a Colours) -> Table<'a> {
|
||||||
let has_git = if let (Some(g), Some(d)) = (git, dir) { g.has_anything_for(&d.path) } else { false };
|
let columns = options.extra_columns.collect(git.is_some());
|
||||||
let columns = options.extra_columns.collect(has_git);
|
|
||||||
let widths = TableWidths::zero(columns.len());
|
let widths = TableWidths::zero(columns.len());
|
||||||
|
|
||||||
Table {
|
Table {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user