From e9e6d99fa06e2e1cc5687dbece5b150323e445cf Mon Sep 17 00:00:00 2001 From: hdwalters Date: Sat, 16 Nov 2024 11:32:34 +0000 Subject: [PATCH] Fix syntax error position at end of file (#69) * Aesthetic changes. * Return correct row and column at EOF. --- src/compiling/failing/position_info.rs | 32 +++++++++++++++----------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/src/compiling/failing/position_info.rs b/src/compiling/failing/position_info.rs index b1135dc..53f801d 100644 --- a/src/compiling/failing/position_info.rs +++ b/src/compiling/failing/position_info.rs @@ -37,22 +37,24 @@ pub struct PositionInfo { impl PositionInfo { /// Create a new erorr from scratch pub fn new(meta: &impl Metadata, position: Position, len: usize) -> Self { - PositionInfo { + let info = PositionInfo { position, path: meta.get_path(), len, data: None - }.updated_pos(meta) + }; + info.updated_pos(meta) } /// Create a new erorr at the end of file pub fn at_eof(meta: &impl Metadata) -> Self { - PositionInfo { + let info = PositionInfo { path: meta.get_path(), position: Position::EOF, len: 0, data: None - }.updated_pos(meta) + }; + info.updated_pos(meta) } /// Create a new erorr at given position @@ -133,7 +135,9 @@ impl PositionInfo { Err(_) => (0, 0) } } - else { (0, 0) } + else { + (0, 0) + } } } } @@ -150,17 +154,17 @@ impl PositionInfo { pub fn get_pos_by_code(&self, code: impl AsRef) -> (usize, usize) { let code = code.as_ref(); match self.position { - Position::Pos(row, col) => (row, col), + Position::Pos(row, col) => { + (row, col) + } Position::EOF => { - let mut col = 1; - let mut row = 1; - // Count letters in column - col += code.split_whitespace().count(); - // Coint letters in row - if let Some(last) = code.split_whitespace().last() { - row += last.len(); + // Add one to `row` because `enumerate()` counts from zero. + // Add one to `col` because `len()` counts from zero. + if let Some((row, line)) = code.lines().enumerate().last() { + (row + 1, line.len() + 1) + } else { + (0, 0) } - (row, col) } } }