From f0865aeb19fb0eaf38248052785622d724a97212 Mon Sep 17 00:00:00 2001 From: Louis Caron Date: Fri, 9 Aug 2024 20:10:33 +0200 Subject: [PATCH] feat: support "0x" format in float values --- a2lfile/src/parser.rs | 30 +++++++++++++++++++++++------- 1 file changed, 23 insertions(+), 7 deletions(-) diff --git a/a2lfile/src/parser.rs b/a2lfile/src/parser.rs index d168128..c105ae6 100644 --- a/a2lfile/src/parser.rs +++ b/a2lfile/src/parser.rs @@ -598,9 +598,16 @@ impl<'a> ParserState<'a> { pub(crate) fn get_float(&mut self, context: &ParseContext) -> Result { let token = self.expect_token(context, A2lTokenType::Number)?; let text = self.get_token_text(token); - match text.parse::() { - Ok(num) => Ok(num), - Err(_) => Err(ParserError::malformed_number(self, context, text)), + if text.starts_with("0x") || text.starts_with("0X") { + match u64::from_str_radix(&text[2..], 16) { + Ok(num) => Ok(num as f32), + Err(_) => Err(ParserError::malformed_number(self, context, text)), + } + } else { + match text.parse::() { + Ok(num) => Ok(num), + Err(_) => Err(ParserError::malformed_number(self, context, text)), + } } } @@ -610,9 +617,16 @@ impl<'a> ParserState<'a> { pub(crate) fn get_double(&mut self, context: &ParseContext) -> Result { let token = self.expect_token(context, A2lTokenType::Number)?; let text = self.get_token_text(token); - match text.parse::() { - Ok(num) => Ok(num), - Err(_) => Err(ParserError::malformed_number(self, context, text)), + if text.starts_with("0x") || text.starts_with("0X") { + match u64::from_str_radix(&text[2..], 16) { + Ok(num) => Ok(num as f64), + Err(_) => Err(ParserError::malformed_number(self, context, text)), + } + } else { + match text.parse::() { + Ok(num) => Ok(num), + Err(_) => Err(ParserError::malformed_number(self, context, text)), + } } } @@ -1154,7 +1168,9 @@ mod tests { // float: 0x11 let res = parser.get_float(&context); - assert!(res.is_err()); + assert!(res.is_ok()); + let val = res.unwrap(); + assert_eq!(val, 17f32); // float: 1.0e+2 let res = parser.get_float(&context);