2018-02-07 19:49:13 -06:00
|
|
|
// Copyright 2017 Jeremy Wall <jeremy@marzhillstudios.com>
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2017-12-09 10:02:45 -06:00
|
|
|
|
2018-02-07 19:49:13 -06:00
|
|
|
//! Errors for use by the ucg compiler.
|
2017-12-09 10:02:45 -06:00
|
|
|
use std::error;
|
|
|
|
use std::fmt;
|
|
|
|
|
2018-05-22 18:02:44 -05:00
|
|
|
use ast::*;
|
2017-12-09 10:02:45 -06:00
|
|
|
|
2018-03-23 18:34:26 -05:00
|
|
|
use nom;
|
|
|
|
|
2018-02-07 19:49:13 -06:00
|
|
|
/// ErrorType defines the various types of errors that can result from compiling UCG into an
|
|
|
|
/// output format.
|
2017-12-09 10:02:45 -06:00
|
|
|
pub enum ErrorType {
|
|
|
|
// Build Errors
|
|
|
|
TypeFail,
|
|
|
|
DuplicateBinding,
|
|
|
|
IncompleteParsing,
|
|
|
|
Unsupported,
|
|
|
|
NoSuchSymbol,
|
|
|
|
BadArgLen,
|
|
|
|
FormatError,
|
|
|
|
// Parsing Errors
|
|
|
|
UnexpectedToken,
|
|
|
|
EmptyExpression,
|
2018-03-23 18:34:26 -05:00
|
|
|
ParseError,
|
2017-12-09 10:02:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
impl fmt::Display for ErrorType {
|
|
|
|
fn fmt(&self, w: &mut fmt::Formatter) -> fmt::Result {
|
|
|
|
let name = match self {
|
|
|
|
&ErrorType::TypeFail => "TypeFail",
|
|
|
|
&ErrorType::DuplicateBinding => "DuplicateBinding",
|
|
|
|
&ErrorType::IncompleteParsing => "IncompleteParsing",
|
|
|
|
&ErrorType::Unsupported => "Unsupported",
|
|
|
|
&ErrorType::NoSuchSymbol => "NoSuchSymbol",
|
|
|
|
&ErrorType::BadArgLen => "BadArgLen",
|
|
|
|
&ErrorType::FormatError => "FormatError",
|
|
|
|
&ErrorType::UnexpectedToken => "UnexpectedToken",
|
|
|
|
&ErrorType::EmptyExpression => "EmptyExpression",
|
2018-03-23 18:34:26 -05:00
|
|
|
&ErrorType::ParseError => "ParseError",
|
2017-12-09 10:02:45 -06:00
|
|
|
};
|
|
|
|
w.write_str(name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-07 19:49:13 -06:00
|
|
|
/// Error defines an Error type for parsing and building UCG code.
|
2017-12-09 10:02:45 -06:00
|
|
|
pub struct Error {
|
|
|
|
pub err_type: ErrorType,
|
|
|
|
pub pos: Position,
|
|
|
|
pub msg: String,
|
2018-03-23 18:34:26 -05:00
|
|
|
pub cause: Option<Box<Error>>,
|
2017-12-09 10:02:45 -06:00
|
|
|
_pkgonly: (),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Error {
|
|
|
|
pub fn new<S: Into<String>>(msg: S, t: ErrorType, pos: Position) -> Self {
|
|
|
|
Error {
|
|
|
|
err_type: t,
|
|
|
|
pos: pos,
|
|
|
|
msg: msg.into(),
|
2018-03-23 18:34:26 -05:00
|
|
|
cause: None,
|
2017-12-09 10:02:45 -06:00
|
|
|
_pkgonly: (),
|
|
|
|
}
|
|
|
|
}
|
2018-03-23 18:34:26 -05:00
|
|
|
|
2018-05-29 20:49:33 -05:00
|
|
|
pub fn new_with_cause<S: Into<String>>(msg: S, t: ErrorType, cause: Error) -> Self {
|
|
|
|
let mut e = Self::new(msg, t, cause.pos.clone());
|
2018-03-23 18:34:26 -05:00
|
|
|
e.cause = Some(Box::new(cause));
|
|
|
|
return e;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn new_with_errorkind<S: Into<String>>(
|
|
|
|
msg: S,
|
|
|
|
t: ErrorType,
|
|
|
|
pos: Position,
|
|
|
|
cause: nom::ErrorKind<Error>,
|
|
|
|
) -> Self {
|
|
|
|
match cause {
|
2018-05-29 20:49:33 -05:00
|
|
|
nom::ErrorKind::Custom(e) => Self::new_with_cause(msg, t, e),
|
2018-03-23 18:34:26 -05:00
|
|
|
_ => Self::new(msg, t, pos),
|
|
|
|
}
|
|
|
|
}
|
2017-12-09 10:02:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
impl fmt::Debug for Error {
|
|
|
|
fn fmt(&self, w: &mut fmt::Formatter) -> fmt::Result {
|
|
|
|
write!(
|
|
|
|
w,
|
2018-03-23 18:34:26 -05:00
|
|
|
"{}: \"{}\" at line: {} column: {}",
|
2018-02-15 19:55:43 -06:00
|
|
|
self.err_type, self.msg, self.pos.line, self.pos.column
|
2017-12-09 10:02:45 -06:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl fmt::Display for Error {
|
|
|
|
fn fmt(&self, w: &mut fmt::Formatter) -> fmt::Result {
|
|
|
|
write!(
|
|
|
|
w,
|
2018-03-23 18:34:26 -05:00
|
|
|
"{}: \"{}\" at line: {} column: {}",
|
2018-02-15 19:55:43 -06:00
|
|
|
self.err_type, self.msg, self.pos.line, self.pos.column
|
2017-12-09 10:02:45 -06:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl error::Error for Error {
|
|
|
|
fn description(&self) -> &str {
|
|
|
|
&self.msg
|
|
|
|
}
|
|
|
|
}
|