mirror of
https://github.com/uutils/coreutils
synced 2024-12-14 07:12:44 +00:00
Merge pull request #4094 from cakebaker/numfmt_field_range_19
numfmt: allow "-" in field list
This commit is contained in:
commit
614c367e46
2 changed files with 15 additions and 8 deletions
|
@ -158,12 +158,15 @@ fn parse_options(args: &ArgMatches) -> Result<NumfmtOptions> {
|
||||||
Ok(0)
|
Ok(0)
|
||||||
}?;
|
}?;
|
||||||
|
|
||||||
let fields = match args.get_one::<String>(options::FIELD).unwrap().as_str() {
|
let fields = args.get_one::<String>(options::FIELD).unwrap().as_str();
|
||||||
"-" => vec![Range {
|
// a lone "-" means "all fields", even as part of a list of fields
|
||||||
|
let fields = if fields.split(',').any(|x| x == "-") {
|
||||||
|
vec![Range {
|
||||||
low: 1,
|
low: 1,
|
||||||
high: std::usize::MAX,
|
high: std::usize::MAX,
|
||||||
}],
|
}]
|
||||||
v => Range::from_list(v)?,
|
} else {
|
||||||
|
Range::from_list(fields)?
|
||||||
};
|
};
|
||||||
|
|
||||||
let format = match args.get_one::<String>(options::FORMAT) {
|
let format = match args.get_one::<String>(options::FORMAT) {
|
||||||
|
|
|
@ -401,11 +401,15 @@ fn test_format_selected_field_range() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_format_all_fields() {
|
fn test_format_all_fields() {
|
||||||
|
let all_fields_patterns = vec!["-", "-,3", "3,-", "1,-,3"];
|
||||||
|
|
||||||
|
for pattern in all_fields_patterns {
|
||||||
new_ucmd!()
|
new_ucmd!()
|
||||||
.args(&["--from=auto", "--field", "-", "1K 2K 3K 4K 5K 6K"])
|
.args(&["--from=auto", "--field", pattern, "1K 2K 3K 4K 5K 6K"])
|
||||||
.succeeds()
|
.succeeds()
|
||||||
.stdout_only("1000 2000 3000 4000 5000 6000\n");
|
.stdout_only("1000 2000 3000 4000 5000 6000\n");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_should_succeed_if_range_out_of_bounds() {
|
fn test_should_succeed_if_range_out_of_bounds() {
|
||||||
|
|
Loading…
Reference in a new issue