mirror of
https://github.com/uutils/coreutils
synced 2025-01-07 10:49:09 +00:00
expand: make error output the same as it was
This commit is contained in:
parent
46d4ebff4c
commit
3411c25112
1 changed files with 19 additions and 9 deletions
|
@ -265,7 +265,7 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
|
|
||||||
let matches = uu_app().try_get_matches_from(expand_shortcuts(&args))?;
|
let matches = uu_app().try_get_matches_from(expand_shortcuts(&args))?;
|
||||||
|
|
||||||
expand(&Options::new(&matches)?).map_err_context(|| "failed to write output".to_string())
|
expand(&Options::new(&matches)?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn uu_app() -> Command {
|
pub fn uu_app() -> Command {
|
||||||
|
@ -308,12 +308,12 @@ pub fn uu_app() -> Command {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn open(path: &str) -> std::io::Result<BufReader<Box<dyn Read + 'static>>> {
|
fn open(path: &str) -> UResult<BufReader<Box<dyn Read + 'static>>> {
|
||||||
let file_buf;
|
let file_buf;
|
||||||
if path == "-" {
|
if path == "-" {
|
||||||
Ok(BufReader::new(Box::new(stdin()) as Box<dyn Read>))
|
Ok(BufReader::new(Box::new(stdin()) as Box<dyn Read>))
|
||||||
} else {
|
} else {
|
||||||
file_buf = File::open(path)?;
|
file_buf = File::open(path).map_err_context(|| path.to_string())?;
|
||||||
Ok(BufReader::new(Box::new(file_buf) as Box<dyn Read>))
|
Ok(BufReader::new(Box::new(file_buf) as Box<dyn Read>))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -367,7 +367,7 @@ enum CharType {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(clippy::cognitive_complexity)]
|
#[allow(clippy::cognitive_complexity)]
|
||||||
fn expand(options: &Options) -> std::io::Result<()> {
|
fn expand(options: &Options) -> UResult<()> {
|
||||||
use self::CharType::*;
|
use self::CharType::*;
|
||||||
|
|
||||||
let mut output = BufWriter::new(stdout());
|
let mut output = BufWriter::new(stdout());
|
||||||
|
@ -428,12 +428,18 @@ fn expand(options: &Options) -> std::io::Result<()> {
|
||||||
// now dump out either spaces if we're expanding, or a literal tab if we're not
|
// now dump out either spaces if we're expanding, or a literal tab if we're not
|
||||||
if init || !options.iflag {
|
if init || !options.iflag {
|
||||||
if nts <= options.tspaces.len() {
|
if nts <= options.tspaces.len() {
|
||||||
output.write_all(options.tspaces[..nts].as_bytes())?;
|
output
|
||||||
|
.write_all(options.tspaces[..nts].as_bytes())
|
||||||
|
.map_err_context(|| "failed to write output".to_string())?;
|
||||||
} else {
|
} else {
|
||||||
output.write_all(" ".repeat(nts).as_bytes())?;
|
output
|
||||||
|
.write_all(" ".repeat(nts).as_bytes())
|
||||||
|
.map_err_context(|| "failed to write output".to_string())?;
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
output.write_all(&buf[byte..byte + nbytes])?;
|
output
|
||||||
|
.write_all(&buf[byte..byte + nbytes])
|
||||||
|
.map_err_context(|| "failed to write output".to_string())?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
|
@ -451,14 +457,18 @@ fn expand(options: &Options) -> std::io::Result<()> {
|
||||||
init = false;
|
init = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
output.write_all(&buf[byte..byte + nbytes])?;
|
output
|
||||||
|
.write_all(&buf[byte..byte + nbytes])
|
||||||
|
.map_err_context(|| "failed to write output".to_string())?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
byte += nbytes; // advance the pointer
|
byte += nbytes; // advance the pointer
|
||||||
}
|
}
|
||||||
|
|
||||||
output.flush()?;
|
output
|
||||||
|
.flush()
|
||||||
|
.map_err_context(|| "failed to write output".to_string())?;
|
||||||
buf.truncate(0); // clear the buffer
|
buf.truncate(0); // clear the buffer
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue