mirror of
https://github.com/uutils/coreutils
synced 2025-01-18 16:14:13 +00:00
migrate cat
code to UResult #2464
This commit is contained in:
parent
52c6593ef5
commit
2106ddd088
1 changed files with 16 additions and 14 deletions
|
@ -23,6 +23,7 @@ use clap::{crate_version, App, Arg};
|
|||
use std::fs::{metadata, File};
|
||||
use std::io::{self, Read, Write};
|
||||
use thiserror::Error;
|
||||
use uucore::error::UResult;
|
||||
|
||||
/// Linux splice support
|
||||
#[cfg(any(target_os = "linux", target_os = "android"))]
|
||||
|
@ -167,7 +168,8 @@ mod options {
|
|||
pub static SHOW_NONPRINTING: &str = "show-nonprinting";
|
||||
}
|
||||
|
||||
pub fn uumain(args: impl uucore::Args) -> i32 {
|
||||
#[uucore_procs::gen_uumain]
|
||||
pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||
let args = args
|
||||
.collect_str(InvalidEncodingHandling::Ignore)
|
||||
.accept_any();
|
||||
|
@ -220,13 +222,7 @@ pub fn uumain(args: impl uucore::Args) -> i32 {
|
|||
show_tabs,
|
||||
squeeze_blank,
|
||||
};
|
||||
let success = cat_files(files, &options).is_ok();
|
||||
|
||||
if success {
|
||||
0
|
||||
} else {
|
||||
1
|
||||
}
|
||||
cat_files(files, &options)
|
||||
}
|
||||
|
||||
pub fn uu_app() -> App<'static, 'static> {
|
||||
|
@ -342,23 +338,29 @@ fn cat_path(path: &str, options: &OutputOptions, state: &mut OutputState) -> Cat
|
|||
}
|
||||
}
|
||||
|
||||
fn cat_files(files: Vec<String>, options: &OutputOptions) -> Result<(), u32> {
|
||||
let mut error_count = 0;
|
||||
fn cat_files(files: Vec<String>, options: &OutputOptions) -> UResult<()> {
|
||||
let mut state = OutputState {
|
||||
line_number: 1,
|
||||
at_line_start: true,
|
||||
};
|
||||
let mut error_messages : Vec<String> = Vec::new();
|
||||
|
||||
for path in &files {
|
||||
if let Err(err) = cat_path(path, options, &mut state) {
|
||||
show_error!("{}: {}", path, err);
|
||||
error_count += 1;
|
||||
error_messages.push(
|
||||
format!("{}: {}", path, err));
|
||||
}
|
||||
}
|
||||
if error_count == 0 {
|
||||
if error_messages.len() == 0 {
|
||||
Ok(())
|
||||
} else {
|
||||
Err(error_count)
|
||||
// each next line is expected to display "cat: …"
|
||||
let line_joiner = format!("\n{}: ",
|
||||
executable!()).to_owned();
|
||||
|
||||
Err(uucore::error::USimpleError::new(
|
||||
error_messages.len() as i32,
|
||||
error_messages.join(&line_joiner).into()))
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue