提交 2bc7fde7 编写于 作者: B Ben S

Allow using --across with --long --grid

上级 6d6e8b78
...@@ -259,7 +259,7 @@ impl View { ...@@ -259,7 +259,7 @@ impl View {
use self::Misfire::*; use self::Misfire::*;
let long = || { let long = || {
if matches.opt_present("across") { if matches.opt_present("across") && !matches.opt_present("grid") {
Err(Useless("across", true, "long")) Err(Useless("across", true, "long"))
} }
else if matches.opt_present("oneline") { else if matches.opt_present("oneline") {
......
...@@ -49,31 +49,67 @@ impl GridDetails { ...@@ -49,31 +49,67 @@ impl GridDetails {
let mut tables: Vec<_> = repeat(()).map(|_| make_table()).take(column_count).collect(); let mut tables: Vec<_> = repeat(()).map(|_| make_table()).take(column_count).collect();
let mut height = cells.len() / column_count; let mut num_cells = cells.len();
if self.details.header {
num_cells += column_count;
}
let mut original_height = cells.len() / column_count;
if cells.len() % column_count != 0 { if cells.len() % column_count != 0 {
original_height += 1;
}
let mut height = num_cells / column_count;
if num_cells % column_count != 0 {
height += 1; height += 1;
} }
for (i, (file, row)) in files.iter().zip(cells.into_iter()).enumerate() { for (i, (file, row)) in files.iter().zip(cells.into_iter()).enumerate() {
tables[i / height].add_file_with_cells(row, file, 0, false, false); let index = if self.grid.across {
i % column_count
}
else {
i / original_height
};
tables[index].add_file_with_cells(row, file, 0, false, false);
} }
let columns: Vec<_> = tables.iter().map(|t| t.print_table(false, false)).collect(); let columns: Vec<_> = tables.iter().map(|t| t.print_table(false, false)).collect();
let direction = grid::Direction::TopToBottom; let direction = if self.grid.across { grid::Direction::LeftToRight }
else { grid::Direction::TopToBottom };
let mut grid = grid::Grid::new(grid::GridOptions { let mut grid = grid::Grid::new(grid::GridOptions {
direction: direction, direction: direction,
separator_width: 4, separator_width: 4,
}); });
for column in columns.iter() { if self.grid.across {
for cell in column.iter() { for row in 0 .. height {
let cell = grid::Cell { for column in columns.iter() {
contents: cell.text.clone(), if row < column.len() {
width: cell.length, let cell = grid::Cell {
}; contents: column[row].text.clone(),
width: column[row].length,
grid.add(cell); };
grid.add(cell);
}
}
}
}
else {
for column in columns.iter() {
for cell in column.iter() {
let cell = grid::Cell {
contents: cell.text.clone(),
width: cell.length,
};
grid.add(cell);
}
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册