1
Fork 0
mirror of https://github.com/RGBCube/uutils-coreutils synced 2025-07-28 03:27:44 +00:00

ls: rustfmt the code

This commit is contained in:
Knight 2016-06-07 20:07:15 +08:00
parent 2713758b52
commit 0394d5398d

View file

@ -1,13 +1,12 @@
#![crate_name = "uu_ls"] #![crate_name = "uu_ls"]
/* // This file is part of the uutils coreutils package.
* This file is part of the uutils coreutils package. //
* // (c) Jeremiah Peschka <jeremiah.peschka@gmail.com>
* (c) Jeremiah Peschka <jeremiah.peschka@gmail.com> //
* // For the full copyright and license information, please view the LICENSE file
* For the full copyright and license information, please view the LICENSE file // that was distributed with this source code.
* that was distributed with this source code. //
*/
extern crate getopts; extern crate getopts;
extern crate pretty_bytes; extern crate pretty_bytes;
@ -22,7 +21,7 @@ use self::libc::c_char;
use getopts::Options; use getopts::Options;
use std::fs; use std::fs;
use std::fs::{ReadDir, DirEntry, FileType, Metadata}; use std::fs::{ReadDir, DirEntry, FileType, Metadata};
use std::ffi::{OsString,CStr}; use std::ffi::{OsString, CStr};
use std::path::Path; use std::path::Path;
use std::io::Write; use std::io::Write;
use std::ptr; use std::ptr;
@ -31,7 +30,7 @@ use std::ptr;
enum Mode { enum Mode {
Help, Help,
Version, Version,
List List,
} }
static NAME: &'static str = "ls"; static NAME: &'static str = "ls";
@ -43,19 +42,37 @@ pub fn uumain(args: Vec<String>) -> i32 {
opts.optflag("", "help", "display this help and exit"); opts.optflag("", "help", "display this help and exit");
opts.optflag("", "version", "output version information and exit"); opts.optflag("", "version", "output version information and exit");
opts.optflag("a", "all", "Do not ignore hidden files (files with names that start with '.')."); opts.optflag("a",
opts.optflag("A", "almost-all", "In a directory, do not ignore all file names that start with '.', only ignore '.' and '..'."); "all",
opts.optflag("B", "ignore-backups", "Ignore files that end with ~. Equivalent to using `--ignore='*~'` or `--ignore='.*~'."); "Do not ignore hidden files (files with names that start with '.').");
opts.optflag("d", "directory", "Only list the names of directories, rather than listing directory contents. This will not follow symbolic links unless one of `--dereference-command-line (-H)`, `--dereference (-L)`, or `--dereference-command-line-symlink-to-dir` is specified."); opts.optflag("A",
opts.optflag("H", "dereference-command-line", "If a command line argument specifies a symbolic link, show information about the linked file rather than the link itself."); "almost-all",
opts.optflag("h", "human-readable", "Print human readable file sizes (e.g. 1K 234M 56G)."); "In a directory, do not ignore all file names that start with '.', only ignore \
'.' and '..'.");
opts.optflag("B",
"ignore-backups",
"Ignore files that end with ~. Equivalent to using `--ignore='*~'` or \
`--ignore='.*~'.");
opts.optflag("d",
"directory",
"Only list the names of directories, rather than listing directory contents. \
This will not follow symbolic links unless one of `--dereference-command-line \
(-H)`, `--dereference (-L)`, or `--dereference-command-line-symlink-to-dir` is \
specified.");
opts.optflag("H",
"dereference-command-line",
"If a command line argument specifies a symbolic link, show information about \
the linked file rather than the link itself.");
opts.optflag("h",
"human-readable",
"Print human readable file sizes (e.g. 1K 234M 56G).");
let matches = match opts.parse(&args[1..]) { let matches = match opts.parse(&args[1..]) {
Ok(m) => m, Ok(m) => m,
Err(e) => { Err(e) => {
show_error!("{}", e); show_error!("{}", e);
panic!() panic!()
}, }
}; };
let mode = if matches.opt_present("version") { let mode = if matches.opt_present("version") {
@ -69,7 +86,7 @@ pub fn uumain(args: Vec<String>) -> i32 {
match mode { match mode {
Mode::Version => version(), Mode::Version => version(),
Mode::Help => help(), Mode::Help => help(),
Mode::List => list(matches) Mode::List => list(matches),
} }
0 0
@ -87,7 +104,9 @@ fn help() {
By default, ls will list the files and contents of any directories on \ By default, ls will list the files and contents of any directories on \
the command line, expect that it will ignore files and directories \ the command line, expect that it will ignore files and directories \
whose names start with '.'. \n\ whose names start with '.'. \n\
\n", NAME, VERSION); \n",
NAME,
VERSION);
println!("{}", msg); println!("{}", msg);
} }
@ -111,7 +130,7 @@ fn list(options: getopts::Matches) {
Err(e) => { Err(e) => {
show_error!("Cannot read directory '{}'. \n Reason: {}", loc, e); show_error!("Cannot read directory '{}'. \n Reason: {}", loc, e);
panic!(); panic!();
}, }
Ok(entries) => enter_directory(entries, &options), Ok(entries) => enter_directory(entries, &options),
}; };
} }
@ -128,8 +147,8 @@ fn enter_directory(contents: ReadDir, options: &getopts::Matches) {
Err(err) => { Err(err) => {
show_error!("{}", err); show_error!("{}", err);
panic!(); panic!();
}, }
Ok(en) => en Ok(en) => en,
}; };
// Currently have a DirEntry that we can believe in. // Currently have a DirEntry that we can believe in.
@ -141,21 +160,21 @@ fn display_dir_entry(entry: DirEntry, options: &getopts::Matches) {
let md = match entry.metadata() { let md = match entry.metadata() {
Err(e) => { Err(e) => {
show_error!("Unable to retrieve metadata for {}. \n Error: {}", show_error!("Unable to retrieve metadata for {}. \n Error: {}",
display_file_name(entry.file_name()), e); display_file_name(entry.file_name()),
e);
panic!(); panic!();
}, }
Ok(md) => md Ok(md) => md,
}; };
println!(" {}{} {} {} {} {: >9} {}", println!("{}{} {} {} {} {: >9} {}",
display_file_type(entry.file_type()), display_file_type(entry.file_type()),
display_permissions(&md), display_permissions(&md),
display_symlink_count(&md), display_symlink_count(&md),
display_uname(&md), display_uname(&md),
display_group(&md), display_group(&md),
display_file_size(&md, options), display_file_size(&md, options),
display_file_name(entry.file_name()) display_file_name(entry.file_name()));
);
} }
fn cstr2string(cstr: *const c_char) -> String { fn cstr2string(cstr: *const c_char) -> String {
@ -216,8 +235,8 @@ fn display_file_type(file_type: Result<FileType, std::io::Error>) -> String {
Err(e) => { Err(e) => {
show_error!("{}", e); show_error!("{}", e);
panic!() panic!()
}, }
Ok(ft) => ft Ok(ft) => ft,
}; };
if file_type.is_dir() { if file_type.is_dir() {