Minimal error display for syntax error

This commit is contained in:
Araozu 2024-01-02 06:31:27 -05:00
parent 6e2b7da22f
commit ef70bc1cc0
2 changed files with 30 additions and 7 deletions

View File

@ -24,8 +24,8 @@
- [x] Hand-make CLI, remove clap
- [x] Compile a single file
- [ ] Display error messages during compilation instead of panicking
- [ ] Improve errror messages
- [x] Display error messages during compilation instead of panicking
- [x] Improve error messages
- [ ] Implement code generation for ast nodes implemented as of now

View File

@ -1,17 +1,24 @@
use std::collections::VecDeque;
use super::{PrintableError, SyntaxError};
use std::collections::VecDeque;
impl PrintableError for SyntaxError {
fn get_error_str(&self, chars: &Vec<char>) -> String {
let (line, before, length) = get_line(chars, self.error_start, self.error_end);
let line_number = get_line_number(chars, self.error_start);
let line_number_whitespace = " ".repeat(line_number.to_string().len());
let whitespace = vec![' '; before].iter().collect::<String>();
let indicator = vec!['^'; length].iter().collect::<String>();
let reason = &self.reason;
format!(
"\n{}\n{}{}\n\n{}{}{}\n{}",
line, whitespace, indicator, "Syntax error at pos ", self.error_start, ":", self.reason
r#"
{line_number_whitespace} |
{line_number } | {line}
{line_number_whitespace} | {whitespace}{indicator}
{reason} at line {line_number}:{before}"#,
)
}
}
@ -90,6 +97,22 @@ fn get_line(
)
}
fn get_line_number(chars: &Vec<char>, target_pos: usize) -> usize {
let mut count = 1;
for (pos, char) in chars.iter().enumerate() {
if pos >= target_pos {
break;
}
if *char == '\n' {
count += 1;
}
}
count
}
#[cfg(test)]
mod tests {
use super::*;