mirror of
https://github.com/uutils/coreutils
synced 2025-01-19 00:24:13 +00:00
Merge pull request #5159 from bluelief/fix-fmt-check-opt_width
fmt: fix panic on width argument
This commit is contained in:
commit
7fcff306af
2 changed files with 33 additions and 1 deletions
|
@ -168,7 +168,7 @@ fn parse_arguments(args: impl uucore::Args) -> UResult<(Vec<String>, FmtOptions)
|
|||
));
|
||||
}
|
||||
};
|
||||
if !matches.get_flag(OPT_WIDTH) {
|
||||
if !matches.contains_id(OPT_WIDTH) {
|
||||
fmt_opts.width = cmp::max(
|
||||
fmt_opts.goal * 100 / DEFAULT_GOAL_TO_WIDTH_RATIO,
|
||||
fmt_opts.goal + 3,
|
||||
|
|
|
@ -43,3 +43,35 @@ fn test_fmt_width_too_big() {
|
|||
.stderr_is("fmt: invalid width: '2501': Numerical result out of range\n");
|
||||
}
|
||||
}
|
||||
|
||||
#[ignore]
|
||||
#[test]
|
||||
fn test_fmt_goal() {
|
||||
for param in ["-g", "--goal"] {
|
||||
new_ucmd!()
|
||||
.args(&["one-word-per-line.txt", param, "7"])
|
||||
.succeeds()
|
||||
.stdout_is("this is a\nfile with one\nword per line\n");
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_fmt_goal_too_big() {
|
||||
for param in ["-g", "--goal"] {
|
||||
new_ucmd!()
|
||||
.args(&["one-word-per-line.txt", "--width=75", param, "76"])
|
||||
.fails()
|
||||
.code_is(1)
|
||||
.stderr_is("fmt: GOAL cannot be greater than WIDTH.\n");
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_fmt_set_goal_not_contain_width() {
|
||||
for param in ["-g", "--goal"] {
|
||||
new_ucmd!()
|
||||
.args(&["one-word-per-line.txt", param, "74"])
|
||||
.succeeds()
|
||||
.stdout_is("this is a file with one word per line\n");
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue