Fork of https://github.com/oxigraph/oxigraph.git for the purpose of NextGraph project
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.
214 lines
6.1 KiB
214 lines
6.1 KiB
use oxrdf::TermParseError;
|
|
use std::error::Error;
|
|
use std::ops::Range;
|
|
use std::sync::Arc;
|
|
use std::{fmt, io};
|
|
|
|
/// Error returned during SPARQL result formats format parsing.
|
|
#[derive(Debug)]
|
|
pub enum ParseError {
|
|
/// I/O error during parsing (file not found...).
|
|
Io(io::Error),
|
|
/// An error in the file syntax.
|
|
Syntax(SyntaxError),
|
|
}
|
|
|
|
impl fmt::Display for ParseError {
|
|
#[inline]
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
match self {
|
|
Self::Io(e) => e.fmt(f),
|
|
Self::Syntax(e) => e.fmt(f),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Error for ParseError {
|
|
#[inline]
|
|
fn source(&self) -> Option<&(dyn Error + 'static)> {
|
|
match self {
|
|
Self::Io(e) => Some(e),
|
|
Self::Syntax(e) => Some(e),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<io::Error> for ParseError {
|
|
#[inline]
|
|
fn from(error: io::Error) -> Self {
|
|
Self::Io(error)
|
|
}
|
|
}
|
|
|
|
impl From<SyntaxError> for ParseError {
|
|
#[inline]
|
|
fn from(error: SyntaxError) -> Self {
|
|
Self::Syntax(error)
|
|
}
|
|
}
|
|
|
|
impl From<ParseError> for io::Error {
|
|
#[inline]
|
|
fn from(error: ParseError) -> Self {
|
|
match error {
|
|
ParseError::Io(error) => error,
|
|
ParseError::Syntax(error) => error.into(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<json_event_parser::ParseError> for ParseError {
|
|
fn from(error: json_event_parser::ParseError) -> Self {
|
|
match error {
|
|
json_event_parser::ParseError::Syntax(error) => SyntaxError::from(error).into(),
|
|
json_event_parser::ParseError::Io(error) => error.into(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<quick_xml::Error> for ParseError {
|
|
#[inline]
|
|
fn from(error: quick_xml::Error) -> Self {
|
|
match error {
|
|
quick_xml::Error::Io(error) => {
|
|
Self::Io(Arc::try_unwrap(error).unwrap_or_else(|e| io::Error::new(e.kind(), e)))
|
|
}
|
|
_ => Self::Syntax(SyntaxError {
|
|
inner: SyntaxErrorKind::Xml(error),
|
|
}),
|
|
}
|
|
}
|
|
}
|
|
|
|
/// An error in the syntax of the parsed file.
|
|
#[derive(Debug)]
|
|
pub struct SyntaxError {
|
|
pub(crate) inner: SyntaxErrorKind,
|
|
}
|
|
|
|
#[derive(Debug)]
|
|
pub(crate) enum SyntaxErrorKind {
|
|
Json(json_event_parser::SyntaxError),
|
|
Xml(quick_xml::Error),
|
|
Term {
|
|
error: TermParseError,
|
|
term: String,
|
|
location: Range<TextPosition>,
|
|
},
|
|
Msg {
|
|
msg: String,
|
|
location: Option<Range<TextPosition>>,
|
|
},
|
|
}
|
|
|
|
impl SyntaxError {
|
|
/// Builds an error from a printable error message.
|
|
#[inline]
|
|
pub(crate) fn msg(msg: impl Into<String>) -> Self {
|
|
Self {
|
|
inner: SyntaxErrorKind::Msg {
|
|
msg: msg.into(),
|
|
location: None,
|
|
},
|
|
}
|
|
}
|
|
|
|
/// Builds an error from a printable error message and a location
|
|
#[inline]
|
|
pub(crate) fn located_message(msg: impl Into<String>, location: Range<TextPosition>) -> Self {
|
|
Self {
|
|
inner: SyntaxErrorKind::Msg {
|
|
msg: msg.into(),
|
|
location: Some(location),
|
|
},
|
|
}
|
|
}
|
|
|
|
/// The location of the error inside of the file.
|
|
#[inline]
|
|
pub fn location(&self) -> Option<Range<TextPosition>> {
|
|
match &self.inner {
|
|
SyntaxErrorKind::Json(e) => {
|
|
let location = e.location();
|
|
Some(
|
|
TextPosition {
|
|
line: location.start.line,
|
|
column: location.start.column,
|
|
offset: location.start.offset,
|
|
}..TextPosition {
|
|
line: location.end.line,
|
|
column: location.end.column,
|
|
offset: location.end.offset,
|
|
},
|
|
)
|
|
}
|
|
SyntaxErrorKind::Term { location, .. } => Some(location.clone()),
|
|
SyntaxErrorKind::Msg { location, .. } => location.clone(),
|
|
SyntaxErrorKind::Xml(_) => None,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl fmt::Display for SyntaxError {
|
|
#[inline]
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
match &self.inner {
|
|
SyntaxErrorKind::Json(e) => e.fmt(f),
|
|
SyntaxErrorKind::Xml(e) => e.fmt(f),
|
|
SyntaxErrorKind::Term {
|
|
error,
|
|
term,
|
|
location,
|
|
} => write!(f, "{error} on '{term}' in line {}", location.start.line + 1),
|
|
SyntaxErrorKind::Msg { msg, .. } => f.write_str(msg),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Error for SyntaxError {
|
|
#[inline]
|
|
fn source(&self) -> Option<&(dyn Error + 'static)> {
|
|
match &self.inner {
|
|
SyntaxErrorKind::Json(e) => Some(e),
|
|
SyntaxErrorKind::Xml(e) => Some(e),
|
|
SyntaxErrorKind::Term { error, .. } => Some(error),
|
|
SyntaxErrorKind::Msg { .. } => None,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<SyntaxError> for io::Error {
|
|
#[inline]
|
|
fn from(error: SyntaxError) -> Self {
|
|
match error.inner {
|
|
SyntaxErrorKind::Json(error) => Self::new(io::ErrorKind::InvalidData, error),
|
|
SyntaxErrorKind::Xml(error) => match error {
|
|
quick_xml::Error::Io(error) => {
|
|
Arc::try_unwrap(error).unwrap_or_else(|e| Self::new(e.kind(), e))
|
|
}
|
|
quick_xml::Error::UnexpectedEof(error) => {
|
|
Self::new(io::ErrorKind::UnexpectedEof, error)
|
|
}
|
|
_ => Self::new(io::ErrorKind::InvalidData, error),
|
|
},
|
|
SyntaxErrorKind::Term { .. } => Self::new(io::ErrorKind::InvalidData, error),
|
|
SyntaxErrorKind::Msg { msg, .. } => Self::new(io::ErrorKind::InvalidData, msg),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<json_event_parser::SyntaxError> for SyntaxError {
|
|
fn from(error: json_event_parser::SyntaxError) -> Self {
|
|
Self {
|
|
inner: SyntaxErrorKind::Json(error),
|
|
}
|
|
}
|
|
}
|
|
|
|
/// A position in a text i.e. a `line` number starting from 0, a `column` number starting from 0 (in number of code points) and a global file `offset` starting from 0 (in number of bytes).
|
|
#[derive(Eq, PartialEq, Debug, Clone, Copy)]
|
|
pub struct TextPosition {
|
|
pub line: u64,
|
|
pub column: u64,
|
|
pub offset: u64,
|
|
}
|
|
|