Rust编写的JavaScript引擎,该项目是一个试验性质的项目。
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

59 lines
1.5 KiB

//! This module contains the errors used by the lexer.
//!
//! More information:
//! - [ECMAScript reference][spec]
//!
//! [spec]: https://tc39.es/ecma262/#sec-native-error-types-used-in-this-standard
use super::Position;
use std::{error::Error as StdError, fmt, io};
#[derive(Debug)]
pub enum Error {
/// An IO error is raised to indicate an issue when the lexer is reading data that isn't
/// related to the sourcecode itself.
IO(io::Error),
/// Indicates a parsing error due to the presence, or lack of, one or more characters.
///
/// More information:
/// - [ECMAScript reference][spec]
///
/// [spec]: https://tc39.es/ecma262/#sec-native-error-types-used-in-this-standard-syntaxerror
Syntax(Box<str>, Position),
}
impl From<io::Error> for Error {
fn from(err: io::Error) -> Self {
Self::IO(err)
}
}
impl Error {
/// Creates a new syntax error.
pub(super) fn syntax<M, P>(err: M, pos: P) -> Self
where
M: Into<Box<str>>,
P: Into<Position>,
{
Self::Syntax(err.into(), pos.into())
}
}
impl fmt::Display for Error {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match self {
Self::IO(e) => write!(f, "I/O error: {}", e),
Self::Syntax(e, pos) => write!(f, "Syntax Error: {} at position: {}", e, pos),
}
}
}
impl StdError for Error {
fn source(&self) -> Option<&(dyn StdError + 'static)> {
match self {
Self::IO(err) => Some(err),
Self::Syntax(_, _) => None,
}
}
}