Merge pull request #5159 from bluelief/fix-fmt-check-opt_width

fmt: fix panic on width argument
This commit is contained in:
Daniel Hofstetter 2023-08-15 07:52:12 +02:00 committed by GitHub
commit 7fcff306af
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 33 additions and 1 deletions

View file

@ -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.width = cmp::max(
fmt_opts.goal * 100 / DEFAULT_GOAL_TO_WIDTH_RATIO, fmt_opts.goal * 100 / DEFAULT_GOAL_TO_WIDTH_RATIO,
fmt_opts.goal + 3, fmt_opts.goal + 3,

View file

@ -43,3 +43,35 @@ fn test_fmt_width_too_big() {
.stderr_is("fmt: invalid width: '2501': Numerical result out of range\n"); .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");
}
}