Move string-to-filenames-vector code to its own function

This commit is contained in:
Ben S 2014-07-05 22:36:43 +01:00
parent 0de80ad7ec
commit 8daeba2617
2 changed files with 27 additions and 31 deletions

View File

@ -26,43 +26,39 @@ fn main() {
match Options::getopts(args) {
Err(err) => println!("Invalid options:\n{}", err),
Ok(opts) => {
if opts.dirs.is_empty() {
exa(&opts, false, ".".to_string())
}
else {
Ok(opts) => exa(&opts),
};
}
fn exa(opts: &Options) {
let mut first = true;
// It's only worth printing out directory names if the user supplied
// more than one of them.
let print_dir_names = opts.dirs.len() > 1;
for dir in opts.dirs.clone().move_iter() {
for dir_name in opts.dirs.clone().move_iter() {
if first {
first = false;
}
else {
print!("\n");
}
exa(&opts, print_dir_names, dir)
}
}
}
};
}
fn exa(options: &Options, print_dir_names: bool, string: String) {
let path = Path::new(string.clone());
let dir = match Dir::readdir(path) {
Ok(dir) => dir,
match Dir::readdir(Path::new(dir_name.clone())) {
Ok(dir) => {
if print_dir_names { println!("{}:", dir_name); }
lines_view(opts, dir);
}
Err(e) => {
println!("{}: {}", string, e);
println!("{}: {}", dir_name, e);
return;
}
};
// Print header *after* readdir must have succeeded
if print_dir_names {
println!("{}:", string);
}
}
fn lines_view(options: &Options, dir: Dir) {
let unsorted_files = dir.files();
let files: Vec<&File> = options.transform_files(&unsorted_files);

View File

@ -50,7 +50,7 @@ impl Options {
reverse: matches.opt_present("reverse"),
header: matches.opt_present("header"),
sortField: matches.opt_str("sort").map(|word| SortField::from_word(word)).unwrap_or(Name),
dirs: matches.free.clone(),
dirs: if matches.free.is_empty() { vec![ ".".to_string() ] } else { matches.free.clone() },
columns: Options::columns(matches),
})
}