From 504b9e15a06ff13fb0fb3e40b4e227148e773eb9 Mon Sep 17 00:00:00 2001 From: Rayhan Faizel Date: Wed, 12 Jul 2023 23:23:58 +0530 Subject: [PATCH 1/2] Clamp overflowing values in --width to maximum --- src/uu/ls/src/ls.rs | 30 ++++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/src/uu/ls/src/ls.rs b/src/uu/ls/src/ls.rs index ae19b133f70..cead745cd54 100644 --- a/src/uu/ls/src/ls.rs +++ b/src/uu/ls/src/ls.rs @@ -17,6 +17,8 @@ use lscolors::LsColors; use number_prefix::NumberPrefix; use once_cell::unsync::OnceCell; use std::collections::HashSet; +use std::num::IntErrorKind; + #[cfg(windows)] use std::os::windows::fs::MetadataExt; use std::{ @@ -657,6 +659,19 @@ fn extract_indicator_style(options: &clap::ArgMatches) -> IndicatorStyle { } } +fn parse_width(s: &str) -> Result { + let radix = match s.starts_with('0') && s.len() > 1 { + true => 8, + false => 10, + }; + match u16::from_str_radix(s, radix) { + Ok(x) => Ok(x), + Err(e) => match e.kind() { + IntErrorKind::PosOverflow => Ok(u16::MAX), + _ => Err(LsError::InvalidLineWidth(s.into())), + }, + } +} impl Config { #[allow(clippy::cognitive_complexity)] pub fn from(options: &clap::ArgMatches) -> UResult { @@ -795,20 +810,7 @@ impl Config { }; let width = match options.get_one::(options::WIDTH) { - Some(x) => { - if x.starts_with('0') && x.len() > 1 { - // Read number as octal - match u16::from_str_radix(x, 8) { - Ok(v) => v, - Err(_) => return Err(LsError::InvalidLineWidth(x.into()).into()), - } - } else { - match x.parse::() { - Ok(u) => u, - Err(_) => return Err(LsError::InvalidLineWidth(x.into()).into()), - } - } - } + Some(x) => parse_width(x)?, None => match terminal_size::terminal_size() { Some((width, _)) => width.0, None => match std::env::var_os("COLUMNS") { From 9e2653423925623ab1405e6e39ca8aa6c7627e13 Mon Sep 17 00:00:00 2001 From: Rayhan Faizel Date: Wed, 12 Jul 2023 23:24:26 +0530 Subject: [PATCH 2/2] tests/ls: Test overflowing decimal and octal values of --width --- tests/by-util/test_ls.rs | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/tests/by-util/test_ls.rs b/tests/by-util/test_ls.rs index 2eef6912162..15ded8e6b22 100644 --- a/tests/by-util/test_ls.rs +++ b/tests/by-util/test_ls.rs @@ -670,6 +670,23 @@ fn test_ls_width() { .stdout_only("test-width-1 test-width-3\ntest-width-2 test-width-4\n"); } + for option in [ + "-w 100000000000000", + "-w=100000000000000", + "--width=100000000000000", + "--width 100000000000000", + "-w 07777777777777777777", + "-w=07777777777777777777", + "--width=07777777777777777777", + "--width 07777777777777777777", + ] { + scene + .ucmd() + .args(&option.split(' ').collect::>()) + .arg("-C") + .succeeds() + .stdout_only("test-width-1 test-width-2 test-width-3 test-width-4\n"); + } scene .ucmd() .arg("-w=bad")