shex_ast 0.2.15

RDF data shapes implementation in Rust
Documentation
use prefixmap::{IriRef, PrefixMapError};
use rudof_iri::{IriS, error::IriSError};
use rudof_rdf::rdf_core::term::literal::{Lang, NumericLiteral};
use thiserror::Error;

use super::shape_label::ShapeLabel;
use crate::ast::TripleExprLabel;
use crate::{Node, ShExFormat, ast};

#[derive(Error, Debug, Clone)]
pub enum SchemaIRError {
    #[error("Pattern  /{regex}/{} trying to match node {node}", flags.as_deref().unwrap_or(""))]
    PatternNodeNotLiteral {
        node: String,
        regex: String,
        flags: Option<String>,
    },

    #[error("Invalid regex /{regex}")]
    InvalidRegex { regex: String },

    #[error("Error matching /{regex}/{flags} with {lexical_form}")]
    PatternError {
        regex: String,
        flags: String,
        lexical_form: String,
    },

    #[error("Error creating language tag: {lang}: {err}")]
    LangTagError { lang: String, err: String },

    #[error("Parsing {str:?} as IRI")]
    Str2IriError { str: String },

    #[error("Parsing {str} as IRI: {err:?}")]
    IriParseError { str: String, err: IriSError },

    #[error("Import IRI error: {error}")]
    ImportIriError { error: String },

    #[error("SchemaJson Error")]
    SchemaJsonError { source: Box<ast::SchemaJsonError> },

    #[error("Duplicated triple expression label in schema: {label:?}")]
    DuplicatedTripleExprLabel { label: Box<TripleExprLabel> },

    #[error("Converting min value {min} must be positive")]
    MinLessZero { min: i32 },

    #[error("Converting max value {max} must be > -1")]
    MaxIncorrect { max: i32 },

    #[error("NodeKind IRI but found {node}")]
    NodeKindIri { node: Node },

    #[error("NodeKind BNode but found {node}")]
    NodeKindBNode { node: Node },

    #[error("NodeKind Literal but found {node}")]
    NodeKindLiteral { node: Node },

    #[error("NodeKind NonLiteral but found {node}")]
    NodeKindNonLiteral { node: Node },

    #[error("Datatype expected {expected} but found {found} for literal with lexical form {lexical_form}")]
    DatatypeDontMatch {
        found: IriRef,
        expected: IriS,
        lexical_form: String,
    },

    #[error("Finding content from iris. Errors: {errors:?}")]
    FindingContentFromIrisError { errors: Vec<SchemaIRError> },

    #[error("Generating candidates from iri {iri}: {error}")]
    CandidatesError { iri: IriS, error: String },

    #[error(
        "Datatype expected {expected} but found a wrong datatype with lexical form {lexical_form} and declared datatype {datatype}: {error}"
    )]
    WrongDatatypeLiteralMatch {
        lexical_form: String,
        datatype: IriRef,
        error: String,
        expected: IriS,
    },

    #[error("Datatype expected {expected} but found literal {node} which has datatype: {}", (*node).datatype().map(|d| d.to_string()).unwrap_or("None".to_string()))]
    DatatypeNoLiteral { expected: Box<IriS>, node: Box<Node> },

    #[error("Datatype expected {expected} but found String literal {lexical_form}")]
    DatatypeDontMatchString { expected: IriRef, lexical_form: String },

    #[error("Datatype expected {expected} but found Integer literal {lexical_form}")]
    DatatypeDontMatchInteger { expected: IriRef, lexical_form: String },

    #[error("Datatype expected {expected} but found decimal literal {lexical_form}")]
    DatatypeDontMatchDecimal { expected: IriRef, lexical_form: String },

    #[error("Datatype expected {expected} but found float literal {lexical_form}")]
    DatatypeDontMatchFloat { expected: IriRef, lexical_form: String },

    #[error("Datatype expected {expected} but found long literal {lexical_form}")]
    DatatypeDontMatchLong { expected: IriRef, lexical_form: String },

    #[error("Datatype expected {expected} but found double literal {lexical_form}")]
    DatatypeDontMatchDouble { expected: IriRef, lexical_form: String },

    #[error("Expected language tag {lang} for StringLiteral with lexical form {lexical_form}")]
    DatatypeDontMatchLangString { lexical_form: String, lang: Box<Lang> },

    #[error("Length of {node} = {found} doesn't match {expected}")]
    LengthError {
        expected: usize,
        found: usize,
        node: String,
    },

    #[error("MinLength of {node} = {found} doesn't match {expected}")]
    MinLengthError {
        expected: usize,
        found: usize,
        node: String,
    },

    #[error("MaxLength of {node} = {found} doesn't match {expected}")]
    MaxLengthError {
        expected: usize,
        found: usize,
        node: String,
    },

    #[error("NumericValue of {node} = {found} doesn't match minInclusive of {expected}")]
    MinInclusiveError {
        expected: NumericLiteral,
        found: NumericLiteral,
        node: String,
    },

    #[error("TotalDigits of {node} = {found} doesn't match {expected}")]
    TotalDigitsError {
        expected: usize,
        found: NumericLiteral,
        node: String,
    },

    #[error("FractionDigits of {node} = {found} doesn't match {expected}")]
    FractionDigitsError {
        expected: usize,
        found: NumericLiteral,
        node: String,
    },

    #[error("NumericValue of {node} = {found} doesn't match minExclusive of {expected}")]
    MinExclusiveError {
        expected: NumericLiteral,
        found: NumericLiteral,
        node: String,
    },

    #[error("NumericValue of {node} = {found} doesn't match maxExclusive of {expected}")]
    MaxExclusiveError {
        expected: NumericLiteral,
        found: NumericLiteral,
        node: String,
    },

    #[error("NumericValue of {node} = {found} doesn't match maxInclusive of {expected}")]
    MaxInclusiveError {
        expected: NumericLiteral,
        found: NumericLiteral,
        node: String,
    },

    #[error("Node {node} is not a numeric literal")]
    NonNumeric { node: String },

    #[error("Shape label not found {shape_label}")]
    ShapeLabelNotFound { shape_label: ShapeLabel },

    #[error("Not implemented yet: {msg}")]
    Todo { msg: String },

    #[error("Can't convert prefixed name {prefix}:{local} to shape label")]
    IriRef2ShapeLabelError { prefix: String, local: String },

    #[error("Can't find prefixed name {prefix}:{local} in prefixmap: {err}")]
    PrefixedNotFound {
        prefix: String,
        local: String,
        err: Box<PrefixMapError>,
    },

    #[error("Label not found: {shape_label}")]
    LabelNotFound { shape_label: ShapeLabel },

    #[error("Semantic action error: {error}")]
    SemanticActionError { error: String },

    #[error("Internal: {msg}")]
    Internal { msg: String },

    #[error("Dereferencing import IRI {iri}: {error}")]
    DereferencingIri { iri: IriS, error: String },

    #[error("Parsing ShExC format from iri: {iri}: {error}")]
    ShExCError { error: String, iri: IriS },

    #[error("Parsing ShExJ format from iri: {iri}: {error}")]
    ShExJError { error: String, iri: IriS },

    #[error("Error importing Schema from iri: {iri}: {}", errors.iter().map(|(format, error)| format!("\nFor {format}: {error}")).collect::<Vec<_>>().join(""))]
    SchemaFromIriRotatingFormats {
        iri: IriS,
        errors: Vec<(ShExFormat, Box<SchemaIRError>)>,
    },

    #[error("Error converting IriRef {prefix}:{local} to Iri: {error}")]
    CnvIriRefError {
        prefix: String,
        local: String,
        error: String,
    },

    #[error("Checking literal datatype. Error converting IriRef {iri_ref} to Iri: {error}")]
    CheckLiteralDatatypeCnvIriRef2IriError { iri_ref: IriRef, error: String },
}