From f83e0d1b04a55feaf7a4dbb810c9dda7a007dc40 Mon Sep 17 00:00:00 2001 From: Terts Diepraam Date: Fri, 17 Nov 2023 14:41:42 +0100 Subject: [PATCH] printf: accept multiple length parameters --- src/uucore/src/lib/features/format/spec.rs | 63 +++++++++++++--------- 1 file changed, 37 insertions(+), 26 deletions(-) diff --git a/src/uucore/src/lib/features/format/spec.rs b/src/uucore/src/lib/features/format/spec.rs index dc55bc653..0f48cdafe 100644 --- a/src/uucore/src/lib/features/format/spec.rs +++ b/src/uucore/src/lib/features/format/spec.rs @@ -107,34 +107,45 @@ impl Spec { None }; - let length = rest.get(0).and_then(|c| { - Some(match c { - b'h' => { - if let Some(b'h') = rest.get(1) { - *rest = &rest[1..]; - Length::Char - } else { - Length::Short + // Parse 0..N length options, keep the last one + // Even though it is just ignored. We might want to use it later and we + // should parse those characters. + // + // TODO: This needs to be configurable: `seq` accepts only one length + // param + let mut _length = None; + loop { + let new_length = rest.get(0).and_then(|c| { + Some(match c { + b'h' => { + if let Some(b'h') = rest.get(1) { + *rest = &rest[1..]; + Length::Char + } else { + Length::Short + } } - } - b'l' => { - if let Some(b'l') = rest.get(1) { - *rest = &rest[1..]; - Length::Long - } else { - Length::LongLong + b'l' => { + if let Some(b'l') = rest.get(1) { + *rest = &rest[1..]; + Length::Long + } else { + Length::LongLong + } } - } - b'j' => Length::IntMaxT, - b'z' => Length::SizeT, - b't' => Length::PtfDiffT, - b'L' => Length::LongDouble, - _ => return None, - }) - }); - - if length.is_some() { - *rest = &rest[1..]; + b'j' => Length::IntMaxT, + b'z' => Length::SizeT, + b't' => Length::PtfDiffT, + b'L' => Length::LongDouble, + _ => return None, + }) + }); + if new_length.is_some() { + *rest = &rest[1..]; + _length = new_length; + } else { + break; + } } let type_spec = rest.get(0)?;