use arbitrary::{Arbitrary, Result, Unstructured}; use std::fmt; use std::iter::once; use std::ops::ControlFlow; pub const DATA_TRIG: &str = " @prefix : . :1 :2 :3 , :4 ; :5 true , 1 , 1.0 , 1e0 . :3 :2 :4 ; :5 false , 0 , 0.0 , 0e0 . "; const NUMBER_OF_NAMED_NODES: u8 = 5; const NUMBER_OF_VARIABLES: u8 = 4; const LITERALS: [&str; 11] = [ "\"foo\"", "\"foo\"^^", "\"foo\"@en", "true", "false", "0", "0.0", "0e0", "1", "1.0", "1e0", ]; pub struct Query { inner: QueryContent, } #[derive(Arbitrary)] struct QueryContent { // [1] QueryUnit ::= Query // [2] Query ::= Prologue ( SelectQuery | ConstructQuery | DescribeQuery | AskQuery ) ValuesClause variant: QueryVariant, values_clause: ValuesClause, } #[derive(Arbitrary)] enum QueryVariant { Select(SelectQuery), // TODO: Other variants! } impl<'a> Arbitrary<'a> for Query { fn arbitrary(u: &mut Unstructured<'a>) -> Result { Ok(Self { inner: QueryContent::arbitrary(u)?, }) } fn arbitrary_take_rest(u: Unstructured<'a>) -> Result { Ok(Self { inner: QueryContent::arbitrary_take_rest(u)?, }) } fn size_hint(_depth: usize) -> (usize, Option) { (20, None) } } impl fmt::Display for Query { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match &self.inner.variant { QueryVariant::Select(s) => write!(f, "{s}"), }?; write!(f, "{}", self.inner.values_clause) } } impl fmt::Debug for Query { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { fmt::Display::fmt(self, f) } } #[derive(Arbitrary)] struct SelectQuery { // [7] SelectQuery ::= SelectClause DatasetClause* WhereClause SolutionModifier select_clause: SelectClause, where_clause: WhereClause, solution_modifier: SolutionModifier, } impl fmt::Display for SelectQuery { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!( f, "{}{}{}", self.select_clause, self.where_clause, self.solution_modifier ) } } #[derive(Arbitrary)] struct SubSelect { // [8] SubSelect ::= SelectClause WhereClause SolutionModifier ValuesClause select_clause: SelectClause, where_clause: WhereClause, solution_modifier: SolutionModifier, values_clause: ValuesClause, } impl fmt::Display for SubSelect { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!( f, "{}{}{}{}", self.select_clause, self.where_clause, self.solution_modifier, self.values_clause ) } } #[derive(Arbitrary)] struct SelectClause { // [9] SelectClause ::= 'SELECT' ( 'DISTINCT' | 'REDUCED' )? ( ( Var | ( '(' Expression 'AS' Var ')' ) )+ | '*' ) option: Option, values: SelectValues, } #[derive(Arbitrary)] enum SelectOption { Distinct, Reduced, } #[derive(Arbitrary)] enum SelectValues { Star, Projection { start: SelectProjection, others: Vec, }, } #[derive(Arbitrary)] enum SelectProjection { Variable(Var), Projection(Expression, Var), } impl fmt::Display for SelectClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { f.write_str("SELECT")?; if let Some(option) = &self.option { match option { SelectOption::Distinct => f.write_str(" DISTINCT"), SelectOption::Reduced => f.write_str(" REDUCED"), }?; } match &self.values { SelectValues::Star => f.write_str(" *"), SelectValues::Projection { start, others } => { for e in once(start).chain(others) { match e { SelectProjection::Variable(v) => write!(f, " {v}"), SelectProjection::Projection(e, v) => write!(f, " ({e} AS {v})"), }?; } Ok(()) } } } } #[derive(Arbitrary)] struct WhereClause { // [17] WhereClause ::= 'WHERE'? GroupGraphPattern with_where: bool, group_graph_pattern: GroupGraphPattern, } impl fmt::Display for WhereClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { if self.with_where { f.write_str(" WHERE ")?; } write!(f, "{}", self.group_graph_pattern) } } #[derive(Arbitrary)] struct SolutionModifier { // [18] SolutionModifier ::= GroupClause? HavingClause? OrderClause? LimitOffsetClauses? group: Option, having: Option, #[cfg(feature = "order")] order: Option, #[cfg(feature = "limit-offset")] limit_offset: Option, } impl fmt::Display for SolutionModifier { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { if let Some(group) = &self.group { write!(f, " {group}")?; } if let Some(having) = &self.having { write!(f, " {having}")?; } #[cfg(feature = "order")] if let Some(order) = &self.order { write!(f, " {order}")?; } #[cfg(feature = "limit-offset")] if let Some(limit_offset) = &self.limit_offset { write!(f, " {limit_offset}")?; } Ok(()) } } #[derive(Arbitrary)] struct GroupClause { // [19] GroupClause ::= 'GROUP' 'BY' GroupCondition+ start: GroupCondition, others: Vec, } impl fmt::Display for GroupClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "GROUP BY {}", self.start)?; for o in &self.others { write!(f, " {o}")?; } Ok(()) } } #[derive(Arbitrary)] enum GroupCondition { // [20] GroupCondition ::= BuiltInCall | FunctionCall | '(' Expression ( 'AS' Var )? ')' | Var BuiltInCall(BuiltInCall), // TODO FunctionCall(FunctionCall) Projection(Expression, Option), Var(Var), } impl fmt::Display for GroupCondition { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::BuiltInCall(c) => write!(f, "{c}"), // Self::FunctionCall(c) => write!(f, "{c}"), Self::Projection(e, v) => { if let Some(v) = v { write!(f, "({e} AS {v})") } else { write!(f, "({e})") } } Self::Var(v) => write!(f, "{v}"), } } } #[derive(Arbitrary)] struct HavingClause { // [21] HavingClause ::= 'HAVING' HavingCondition+ start: HavingCondition, others: Vec, } impl fmt::Display for HavingClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "HAVING {}", self.start)?; for o in &self.others { write!(f, " {o}")?; } Ok(()) } } // [22] HavingCondition ::= Constraint type HavingCondition = Constraint; #[cfg(feature = "order")] #[derive(Arbitrary)] struct OrderClause { // [23] OrderClause ::= 'ORDER' 'BY' OrderCondition+ start: OrderCondition, others: Vec, } #[cfg(feature = "order")] impl fmt::Display for OrderClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "ORDER BY {}", self.start)?; for other in &self.others { write!(f, " {other}")?; } Ok(()) } } #[cfg(feature = "order")] #[derive(Arbitrary)] enum OrderCondition { // [24] OrderCondition ::= ( ( 'ASC' | 'DESC' ) BrackettedExpression ) | ( Constraint | Var ) BrackettedExpression { is_asc: bool, inner: BrackettedExpression, }, Constraint(Constraint), Var(Var), } #[cfg(feature = "order")] impl fmt::Display for OrderCondition { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::BrackettedExpression { is_asc, inner } => { if *is_asc { write!(f, "ASC{inner}") } else { write!(f, "DESC{inner}") } } Self::Constraint(c) => write!(f, "{c}"), Self::Var(v) => write!(f, "{v}"), } } } #[cfg(feature = "limit-offset")] #[derive(Arbitrary)] enum LimitOffsetClauses { // [25] LimitOffsetClauses ::= LimitClause OffsetClause? | OffsetClause LimitClause? LimitOffset(LimitClause, Option), OffsetLimit(OffsetClause, Option), } #[cfg(feature = "limit-offset")] impl fmt::Display for LimitOffsetClauses { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::LimitOffset(l, Some(o)) => write!(f, "{l} {o}"), Self::LimitOffset(l, None) => write!(f, "{l}"), Self::OffsetLimit(o, Some(l)) => write!(f, "{o} {l}"), Self::OffsetLimit(o, None) => write!(f, "{o}"), } } } #[cfg(feature = "limit-offset")] #[derive(Arbitrary)] struct LimitClause { // [26] LimitClause ::= 'LIMIT' INTEGER value: u8, } #[cfg(feature = "limit-offset")] impl fmt::Display for LimitClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "LIMIT {}", self.value) } } #[cfg(feature = "limit-offset")] #[derive(Arbitrary)] struct OffsetClause { // [27] OffsetClause ::= 'OFFSET' INTEGER value: u8, } #[cfg(feature = "limit-offset")] impl fmt::Display for OffsetClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "OFFSET {}", self.value) } } #[derive(Arbitrary)] struct ValuesClause { // [28] ValuesClause ::= ( 'VALUES' DataBlock )? value: Option, } impl fmt::Display for ValuesClause { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { if let Some(value) = &self.value { write!(f, " VALUES {value}") } else { Ok(()) } } } #[derive(Arbitrary)] enum GroupGraphPattern { // [53] GroupGraphPattern ::= '{' ( SubSelect | GroupGraphPatternSub ) '}' GroupGraphPatternSub(GroupGraphPatternSub), SubSelect(Box), } impl fmt::Display for GroupGraphPattern { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { f.write_str(" { ")?; match self { Self::GroupGraphPatternSub(p) => write!(f, "{p}"), Self::SubSelect(s) => write!(f, "{s}"), }?; f.write_str(" } ") } } #[derive(Arbitrary)] struct GroupGraphPatternSub { // [54] GroupGraphPatternSub ::= TriplesBlock? ( GraphPatternNotTriples '.'? TriplesBlock? )* start: Option, others: Vec, } #[derive(Arbitrary)] struct GroupGraphPatternSubOtherBlock { start: GraphPatternNotTriples, with_dot: bool, end: Option, } impl fmt::Display for GroupGraphPatternSub { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { if let Some(start) = &self.start { write!(f, "{start}")?; } for other in &self.others { write!(f, "{}", other.start)?; if other.with_dot { f.write_str(" . ")?; } if let Some(end) = &other.end { write!(f, "{end}")?; } } Ok(()) } } #[derive(Arbitrary)] struct TriplesBlock { // [55] TriplesBlock ::= TriplesSameSubjectPath ( '.' TriplesBlock? )? start: TriplesSameSubjectPath, end: Option>>, } impl fmt::Display for TriplesBlock { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; if let Some(end) = &self.end { f.write_str(" . ")?; if let Some(end) = end { write!(f, "{end}")?; } } Ok(()) } } #[derive(Arbitrary)] enum GraphPatternNotTriples { // [56] GraphPatternNotTriples ::= GroupOrUnionGraphPattern | OptionalGraphPattern | MinusGraphPattern | GraphGraphPattern | ServiceGraphPattern | Filter | Bind | InlineData GroupOrUnion(GroupOrUnionGraphPattern), Optional(OptionalGraphPattern), Minus(MinusGraphPattern), Graph(GraphGraphPattern), Filter(Filter), Bind(Bind), InlineData(InlineData), // TODO: ServiceGraphPattern #[cfg(feature = "sep-0006")] Lateral(LateralGraphPattern), } impl fmt::Display for GraphPatternNotTriples { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::GroupOrUnion(p) => write!(f, "{p}"), Self::Optional(p) => write!(f, "{p}"), Self::Minus(p) => write!(f, "{p}"), Self::Graph(p) => write!(f, "{p}"), Self::Filter(p) => write!(f, "{p}"), Self::Bind(p) => write!(f, "{p}"), Self::InlineData(p) => write!(f, "{p}"), #[cfg(feature = "sep-0006")] Self::Lateral(p) => write!(f, "{p}"), } } } #[derive(Arbitrary)] struct OptionalGraphPattern { // [57] OptionalGraphPattern ::= 'OPTIONAL' GroupGraphPattern inner: GroupGraphPattern, } impl fmt::Display for OptionalGraphPattern { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, " OPTIONAL {}", self.inner) } } #[derive(Arbitrary)] struct LateralGraphPattern { // [] LateralGraphPattern ::= 'LATERAL' GroupGraphPattern inner: GroupGraphPattern, } impl fmt::Display for LateralGraphPattern { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, " LATERAL {}", self.inner) } } #[derive(Arbitrary)] struct GraphGraphPattern { // [58] GraphGraphPattern ::= 'GRAPH' VarOrIri GroupGraphPattern graph: VarOrIri, inner: GroupGraphPattern, } impl fmt::Display for GraphGraphPattern { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, " GRAPH {} {}", self.graph, self.inner) } } #[derive(Arbitrary)] struct Bind { // [60] Bind ::= 'BIND' '(' Expression 'AS' Var ')' expression: Expression, var: Var, } impl fmt::Display for Bind { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, " BIND({} AS {})", self.expression, self.var) } } #[derive(Arbitrary)] struct InlineData { // [61] InlineData ::= 'VALUES' DataBlock inner: DataBlock, } impl fmt::Display for InlineData { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "VALUES {}", self.inner) } } #[derive(Arbitrary)] enum DataBlock { // [62] DataBlock ::= InlineDataOneVar | InlineDataFull OneVar(InlineDataOneVar), Full(InlineDataFull), } impl fmt::Display for DataBlock { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::OneVar(e) => write!(f, "{e}"), Self::Full(c) => write!(f, "{c}"), } } } #[derive(Arbitrary)] struct InlineDataOneVar { // [63] InlineDataOneVar ::= Var '{' DataBlockValue* '}' var: Var, values: Vec, } impl fmt::Display for InlineDataOneVar { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{} {{", self.var)?; for v in &self.values { write!(f, " {v}")?; } write!(f, " }}") } } struct InlineDataFull { // [64] InlineDataFull ::= ( NIL | '(' Var* ')' ) '{' ( '(' DataBlockValue* ')' | NIL )* '}' vars: Vec, values: Vec>, } impl<'a> Arbitrary<'a> for InlineDataFull { fn arbitrary(u: &mut Unstructured<'a>) -> Result { let vars = u.arbitrary_iter()?.collect::>>()?; let mut values = Vec::new(); u.arbitrary_loop(Some(0), Some(3), |u| { let mut row = Vec::with_capacity(vars.len()); u.arbitrary_loop( Some(vars.len().try_into().unwrap()), Some(vars.len().try_into().unwrap()), |u| { row.push(u.arbitrary()?); Ok(ControlFlow::Continue(())) }, )?; values.push(row); Ok(ControlFlow::Continue(())) })?; Ok(Self { vars, values }) } } impl fmt::Display for InlineDataFull { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { f.write_str("( ")?; for v in &self.vars { write!(f, " {v}")?; } f.write_str(" ) {")?; for vs in &self.values { f.write_str(" (")?; for v in vs { write!(f, " {v}")?; } f.write_str(" )")?; } f.write_str(" }") } } #[derive(Arbitrary)] enum DataBlockValue { // [65] DataBlockValue ::= iri | RDFLiteral | NumericLiteral | BooleanLiteral | 'UNDEF' Iri(Iri), Literal(Literal), Undef, } impl fmt::Display for DataBlockValue { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Iri(i) => write!(f, "{i}"), Self::Literal(l) => write!(f, "{l}"), Self::Undef => f.write_str("UNDEF"), } } } #[derive(Arbitrary)] struct MinusGraphPattern { // [66] MinusGraphPattern ::= 'MINUS' GroupGraphPattern inner: GroupGraphPattern, } impl fmt::Display for MinusGraphPattern { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, " MINUS {}", self.inner) } } #[derive(Arbitrary)] struct GroupOrUnionGraphPattern { // [67] GroupOrUnionGraphPattern ::= GroupGraphPattern ( 'UNION' GroupGraphPattern )* start: GroupGraphPattern, others: Vec, } impl fmt::Display for GroupOrUnionGraphPattern { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; for other in &self.others { write!(f, " UNION {other}")?; } Ok(()) } } #[derive(Arbitrary)] struct Filter { // [68] Filter ::= 'FILTER' Constraint constraint: Constraint, } impl fmt::Display for Filter { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "FILTER {}", self.constraint) } } #[derive(Arbitrary)] enum Constraint { // [69] Constraint ::= BrackettedExpression | BuiltInCall | FunctionCall BrackettedExpression(BrackettedExpression), BuiltInCall(BuiltInCall), // TODO FunctionCall(FunctionCall), } impl fmt::Display for Constraint { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::BrackettedExpression(e) => write!(f, "{e}"), Self::BuiltInCall(c) => write!(f, "{c}"), // Self::FunctionCall(c) => write!(f, "{c}"), } } } #[derive(Arbitrary)] struct FunctionCall { // [70] FunctionCall ::= iri ArgList iri: Iri, args: ArgList, } impl fmt::Display for FunctionCall { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}{}", self.iri, self.args) } } #[derive(Arbitrary)] enum ArgList { // [71] ArgList ::= NIL | '(' 'DISTINCT'? Expression ( ',' Expression )* ')' Nil, NotNil { // TODO: DISTINCT start: Box, others: Vec, }, } impl fmt::Display for ArgList { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { f.write_str("(")?; if let Self::NotNil { start, others } = self { write!(f, "{start}")?; for e in others { write!(f, ", {e}")?; } } f.write_str(")") } } #[derive(Arbitrary)] struct ExpressionList { // [72] ExpressionList ::= NIL | '(' Expression ( ',' Expression )* ')' inner: Vec, } impl fmt::Display for ExpressionList { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { f.write_str("(")?; for (i, e) in self.inner.iter().enumerate() { if i > 0 { f.write_str(", ")?; } write!(f, "{e}")?; } f.write_str(")") } } #[derive(Arbitrary)] struct PropertyListNotEmpty { // [77] PropertyListNotEmpty ::= Verb ObjectList ( ';' ( Verb ObjectList )? )* start_predicate: Verb, start_object: Box, others: Vec>, } #[derive(Arbitrary)] struct PropertyListElement { predicate: Verb, object: ObjectList, } impl fmt::Display for PropertyListNotEmpty { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{} {}", self.start_predicate, self.start_object)?; for other in &self.others { f.write_str(" ; ")?; if let Some(e) = other { write!(f, "{} {}", e.predicate, e.object)?; } } Ok(()) } } #[derive(Arbitrary)] enum Verb { // [78] Verb ::= VarOrIri | 'a' VarOrIri(VarOrIri), A, } impl fmt::Display for Verb { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::VarOrIri(iri) => write!(f, "{iri}"), Self::A => f.write_str(" a "), } } } #[derive(Arbitrary)] struct ObjectList { // [79] ObjectList ::= Object ( ',' Object )* start: Object, others: Vec, } impl fmt::Display for ObjectList { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; for other in &self.others { f.write_str(" , ")?; write!(f, "{other}")?; } Ok(()) } } // [80] Object ::= GraphNode type Object = GraphNode; #[derive(Arbitrary)] enum TriplesSameSubjectPath { // [81] TriplesSameSubjectPath ::= VarOrTerm PropertyListPathNotEmpty | TriplesNodePath PropertyListPath Atomic { subject: VarOrTerm, predicate_object: PropertyListPathNotEmpty, }, Other { subject: TriplesNodePath, predicate_object: PropertyListPath, }, } impl fmt::Display for TriplesSameSubjectPath { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Atomic { subject, predicate_object, } => { write!(f, "{subject}{predicate_object}") } Self::Other { subject, predicate_object, } => { write!(f, "{subject} {predicate_object}") } } } } #[derive(Arbitrary)] struct PropertyListPath { // [82] PropertyListPath ::= PropertyListPathNotEmpty? inner: Option, } impl fmt::Display for PropertyListPath { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { if let Some(p) = &self.inner { write!(f, "{p}") } else { Ok(()) } } } #[derive(Arbitrary)] struct PropertyListPathNotEmpty { // [83] PropertyListPathNotEmpty ::= ( VerbPath | VerbSimple ) ObjectListPath ( ';' ( ( VerbPath | VerbSimple ) ObjectListPath )? )* start_predicate: PropertyListPathNotEmptyVerb, start_object: Box, others: Vec>, } #[derive(Arbitrary)] enum PropertyListPathNotEmptyVerb { VerbPath(VerbPath), VerbSimple(VerbSimple), } #[derive(Arbitrary)] struct PropertyListPathElement { predicate: PropertyListPathNotEmptyVerb, object: ObjectListPath, } impl fmt::Display for PropertyListPathNotEmpty { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match &self.start_predicate { PropertyListPathNotEmptyVerb::VerbPath(p) => write!(f, "{p}"), PropertyListPathNotEmptyVerb::VerbSimple(s) => write!(f, "{s}"), }?; write!(f, "{}", self.start_object)?; for other in &self.others { f.write_str(" ; ")?; if let Some(e) = other { match &e.predicate { PropertyListPathNotEmptyVerb::VerbPath(p) => write!(f, "{p}"), PropertyListPathNotEmptyVerb::VerbSimple(s) => write!(f, "{s}"), }?; write!(f, "{}", e.object)?; } } Ok(()) } } // [84] VerbPath ::= Path type VerbPath = Path; // [85] VerbSimple ::= Var type VerbSimple = Var; #[derive(Arbitrary)] struct ObjectListPath { // [86] ObjectListPath ::= ObjectPath ( ',' ObjectPath )* start: ObjectPath, others: Vec, } impl fmt::Display for ObjectListPath { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; for other in &self.others { write!(f, " , {other}")?; } Ok(()) } } // [87] ObjectPath ::= GraphNodePath type ObjectPath = GraphNodePath; // [88] Path ::= PathAlternative type Path = PathAlternative; #[derive(Arbitrary)] struct PathAlternative { // [89] PathAlternative ::= PathSequence ( '|' PathSequence )* start: PathSequence, others: Vec, } impl fmt::Display for PathAlternative { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; for other in &self.others { write!(f, " | {other}")?; } Ok(()) } } #[derive(Arbitrary)] struct PathSequence { // [90] PathSequence ::= PathEltOrInverse ( '/' PathEltOrInverse )* start: PathEltOrInverse, others: Vec, } impl fmt::Display for PathSequence { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; for other in &self.others { write!(f, " / {other}")?; } Ok(()) } } #[derive(Arbitrary)] struct PathElt { // [91] PathElt ::= PathPrimary PathMod? path: PathPrimary, mode: Option, } impl fmt::Display for PathElt { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.path)?; if let Some(mode) = &self.mode { write!(f, "{mode}")?; } Ok(()) } } #[derive(Arbitrary)] enum PathEltOrInverse { // [92] PathEltOrInverse ::= PathElt | '^' PathElt PathElt(PathElt), Inverse(PathElt), } impl fmt::Display for PathEltOrInverse { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::PathElt(e) => write!(f, "{e}"), Self::Inverse(e) => write!(f, " ^{e}"), } } } #[derive(Arbitrary)] enum PathMod { // [93] PathMod ::= '?' | '*' | '+' ZeroOrOne, ZeroOrMore, OneOrMore, } impl fmt::Display for PathMod { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::ZeroOrOne => f.write_str(" ? "), Self::ZeroOrMore => f.write_str(" * "), Self::OneOrMore => f.write_str(" + "), } } } #[derive(Arbitrary)] enum PathPrimary { // [94] PathPrimary ::= iri | 'a' | '!' PathNegatedPropertySet | '(' Path ')' Iri(Iri), A, Negated(PathNegatedPropertySet), Child(Box), } impl fmt::Display for PathPrimary { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Iri(iri) => write!(f, "{iri}"), Self::A => f.write_str(" a "), Self::Negated(n) => write!(f, "!{n}"), Self::Child(c) => write!(f, "({c})"), } } } #[derive(Arbitrary)] enum PathNegatedPropertySet { // [95] PathNegatedPropertySet ::= PathOneInPropertySet | '(' ( PathOneInPropertySet ( '|' PathOneInPropertySet )* )? ')' Single(PathOneInPropertySet), Multiple { start: PathOneInPropertySet, others: Vec, }, } impl fmt::Display for PathNegatedPropertySet { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Single(p) => write!(f, "{p}"), Self::Multiple { start, others } => { write!(f, " ( {start}")?; for other in others { write!(f, " | {other}")?; } f.write_str(" ) ") } } } } #[derive(Arbitrary)] enum PathOneInPropertySet { // [96] PathOneInPropertySet ::= iri | 'a' | '^' ( iri | 'a' ) Iri(Iri), A, NegatedIri(Iri), NegatedA, } impl fmt::Display for PathOneInPropertySet { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Iri(iri) => write!(f, "{iri}"), Self::A => f.write_str(" a "), Self::NegatedIri(iri) => write!(f, "^{iri}"), Self::NegatedA => f.write_str(" ^a "), } } } #[derive(Arbitrary)] enum TriplesNode { // [98] TriplesNode ::= Collection | BlankNodePropertyList Collection(Collection), BlankNodePropertyList(BlankNodePropertyList), } impl fmt::Display for TriplesNode { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Collection(p) => write!(f, "{p}"), Self::BlankNodePropertyList(p) => write!(f, "{p}"), } } } #[derive(Arbitrary)] struct BlankNodePropertyList { // [99] BlankNodePropertyList ::= '[' PropertyListNotEmpty ']' inner: PropertyListNotEmpty, } impl fmt::Display for BlankNodePropertyList { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "[ {} ]", self.inner) } } #[derive(Arbitrary)] enum TriplesNodePath { // [100] TriplesNodePath ::= CollectionPath | BlankNodePropertyListPath CollectionPath(CollectionPath), BlankNodePropertyListPath(BlankNodePropertyListPath), } impl fmt::Display for TriplesNodePath { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::CollectionPath(p) => write!(f, "{p}"), Self::BlankNodePropertyListPath(p) => write!(f, "{p}"), } } } #[derive(Arbitrary)] struct BlankNodePropertyListPath { // [101] BlankNodePropertyListPath ::= '[' PropertyListPathNotEmpty ']' inner: PropertyListPathNotEmpty, } impl fmt::Display for BlankNodePropertyListPath { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "[ {} ]", self.inner) } } #[derive(Arbitrary)] struct Collection { // [102] Collection ::= '(' GraphNode+ ')' start: Box, others: Vec, } impl fmt::Display for Collection { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "( {}", self.start)?; for e in &self.others { write!(f, " {e}")?; } f.write_str(" )") } } #[derive(Arbitrary)] struct CollectionPath { // [103] CollectionPath ::= '(' GraphNodePath+ ')' start: Box, others: Vec, } impl fmt::Display for CollectionPath { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "( {}", self.start)?; for e in &self.others { write!(f, " {e}")?; } f.write_str(" )") } } #[derive(Arbitrary)] enum GraphNode { // [104] GraphNode ::= VarOrTerm | TriplesNode VarOrTerm(VarOrTerm), TriplesNode(TriplesNode), } impl fmt::Display for GraphNode { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::VarOrTerm(t) => write!(f, "{t}"), Self::TriplesNode(t) => write!(f, "{t}"), } } } #[derive(Arbitrary)] enum GraphNodePath { // [105] GraphNodePath ::= VarOrTerm | TriplesNodePath VarOrTerm(VarOrTerm), TriplesNodePath(TriplesNodePath), } impl fmt::Display for GraphNodePath { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::VarOrTerm(t) => write!(f, "{t}"), Self::TriplesNodePath(p) => write!(f, "{p}"), } } } #[derive(Arbitrary)] enum VarOrTerm { // [106] VarOrTerm ::= Var | GraphTerm Var(Var), GraphTerm(GraphTerm), } impl fmt::Display for VarOrTerm { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Var(v) => write!(f, "{v}"), Self::GraphTerm(t) => write!(f, "{t}"), } } } #[derive(Arbitrary)] enum VarOrIri { // [107] VarOrIri ::= Var | iri Var(Var), Iri(Iri), } impl fmt::Display for VarOrIri { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Var(v) => write!(f, "{v}"), Self::Iri(t) => write!(f, "{t}"), } } } struct Var { // [108] Var ::= VAR1 | VAR2 value: u8, } impl Arbitrary<'_> for Var { fn arbitrary(u: &mut Unstructured<'_>) -> Result { Ok(Self { value: u.int_in_range(1..=NUMBER_OF_VARIABLES)?, }) } fn size_hint(depth: usize) -> (usize, Option) { ::size_hint(depth) } } impl fmt::Display for Var { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, " ?{} ", self.value) } } #[derive(Arbitrary)] enum GraphTerm { // [109] GraphTerm ::= iri | RDFLiteral | NumericLiteral | BooleanLiteral | BlankNode | NIL Iri(Iri), Literal(Literal), Nil, // TODO: BlankNode } impl fmt::Display for GraphTerm { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Iri(iri) => write!(f, "{iri}"), Self::Literal(l) => write!(f, "{l}"), Self::Nil => f.write_str(" () "), } } } // [110] Expression ::= ConditionalOrExpression type Expression = ConditionalOrExpression; #[derive(Arbitrary)] struct ConditionalOrExpression { // [111] ConditionalOrExpression ::= ConditionalAndExpression ( '||' ConditionalAndExpression )* start: ConditionalAndExpression, others: Vec, } impl fmt::Display for ConditionalOrExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; for e in &self.others { write!(f, " || {e}")?; } Ok(()) } } #[derive(Arbitrary)] struct ConditionalAndExpression { // [112] ConditionalAndExpression ::= ValueLogical ( '&&' ValueLogical )* start: ValueLogical, others: Vec, } impl fmt::Display for ConditionalAndExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.start)?; for e in &self.others { write!(f, " && {e}")?; } Ok(()) } } // [113] ValueLogical ::= RelationalExpression type ValueLogical = RelationalExpression; #[derive(Arbitrary)] enum RelationalExpression { // [114] RelationalExpression ::= NumericExpression ( '=' NumericExpression | '!=' NumericExpression | '<' NumericExpression | '>' NumericExpression | '<=' NumericExpression | '>=' NumericExpression | 'IN' ExpressionList | 'NOT' 'IN' ExpressionList )? Base(NumericExpression), Equal(NumericExpression, NumericExpression), NotEqual(NumericExpression, NumericExpression), Less(NumericExpression, NumericExpression), LessOrEqual(NumericExpression, NumericExpression), Greater(NumericExpression, NumericExpression), GreaterOrEqual(NumericExpression, NumericExpression), In(NumericExpression, ExpressionList), NotIn(NumericExpression, ExpressionList), } impl fmt::Display for RelationalExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Base(e) => write!(f, "{e}"), Self::Equal(a, b) => write!(f, "{a} = {b}"), Self::NotEqual(a, b) => write!(f, "{a} != {b}"), Self::Less(a, b) => write!(f, "{a} < {b}"), Self::LessOrEqual(a, b) => write!(f, "{a} <= {b}"), Self::Greater(a, b) => write!(f, "{a} > {b}"), Self::GreaterOrEqual(a, b) => write!(f, "{a} >= {b}"), Self::In(a, b) => write!(f, "{a} IN {b}"), Self::NotIn(a, b) => write!(f, "{a} NOT IN {b}"), } } } // [115] NumericExpression ::= AdditiveExpression type NumericExpression = AdditiveExpression; #[derive(Arbitrary)] enum AdditiveExpression { // [116] AdditiveExpression ::= MultiplicativeExpression ( '+' MultiplicativeExpression | '-' MultiplicativeExpression | ( NumericLiteralPositive | NumericLiteralNegative ) ( ( '*' UnaryExpression ) | ( '/' UnaryExpression ) )* )* Base(MultiplicativeExpression), Plus(MultiplicativeExpression, MultiplicativeExpression), Minus(MultiplicativeExpression, MultiplicativeExpression), // TODO: Prefix + and - } impl fmt::Display for AdditiveExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Base(e) => write!(f, "{e}"), Self::Plus(a, b) => write!(f, "{a} + {b}"), Self::Minus(a, b) => write!(f, "{a} - {b}"), } } } #[derive(Arbitrary)] enum MultiplicativeExpression { // [117] MultiplicativeExpression ::= UnaryExpression ( '*' UnaryExpression | '/' UnaryExpression )* Base(UnaryExpression), Mul(UnaryExpression, UnaryExpression), Div(UnaryExpression, UnaryExpression), } impl fmt::Display for MultiplicativeExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Base(e) => write!(f, "{e}"), Self::Mul(a, b) => write!(f, "{a} * {b}"), Self::Div(a, b) => write!(f, "{a} / {b}"), } } } #[derive(Arbitrary)] enum UnaryExpression { // [118] UnaryExpression ::= '!' PrimaryExpression | '+' PrimaryExpression | '-' PrimaryExpression | PrimaryExpression Not(PrimaryExpression), Plus(PrimaryExpression), Minus(PrimaryExpression), Base(PrimaryExpression), } impl fmt::Display for UnaryExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Not(e) => write!(f, "!{e}"), Self::Plus(e) => write!(f, "+{e}"), Self::Minus(e) => write!(f, "-{e}"), Self::Base(e) => write!(f, "{e}"), } } } #[derive(Arbitrary)] enum PrimaryExpression { // [119] PrimaryExpression ::= BrackettedExpression | BuiltInCall | iriOrFunction | RDFLiteral | NumericLiteral | BooleanLiteral | Var Bracketted(BrackettedExpression), BuiltInCall(BuiltInCall), IriOrFunction(IriOrFunction), Literal(Literal), Var(Var), } impl fmt::Display for PrimaryExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Bracketted(e) => write!(f, "{e}"), Self::BuiltInCall(e) => write!(f, "{e}"), Self::IriOrFunction(e) => write!(f, "{e}"), Self::Literal(e) => write!(f, "{e}"), Self::Var(e) => write!(f, "{e}"), } } } #[derive(Arbitrary)] struct BrackettedExpression { // [120] BrackettedExpression ::= '(' Expression ')' inner: Box, } impl fmt::Display for BrackettedExpression { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "({})", self.inner) } } #[derive(Arbitrary)] enum BuiltInCall { // [121] BuiltInCall ::= Aggregate // | 'STR' '(' Expression ')' // | 'LANG' '(' Expression ')' // | 'LANGMATCHES' '(' Expression ',' Expression ')' // | 'DATATYPE' '(' Expression ')' // | 'BOUND' '(' Var ')' // | 'IRI' '(' Expression ')' // | 'URI' '(' Expression ')' // | 'BNODE' ( '(' Expression ')' | NIL ) // | 'RAND' NIL // | 'ABS' '(' Expression ')' // | 'CEIL' '(' Expression ')' // | 'FLOOR' '(' Expression ')' // | 'ROUND' '(' Expression ')' // | 'CONCAT' ExpressionList // | SubstringExpression // | 'STRLEN' '(' Expression ')' // | StrReplaceExpression // | 'UCASE' '(' Expression ')' // | 'LCASE' '(' Expression ')' // | 'ENCODE_FOR_URI' '(' Expression ')' // | 'CONTAINS' '(' Expression ',' Expression ')' // | 'STRSTARTS' '(' Expression ',' Expression ')' // | 'STRENDS' '(' Expression ',' Expression ')' // | 'STRBEFORE' '(' Expression ',' Expression ')' // | 'STRAFTER' '(' Expression ',' Expression ')' // | 'YEAR' '(' Expression ')' // | 'MONTH' '(' Expression ')' // | 'DAY' '(' Expression ')' // | 'HOURS' '(' Expression ')' // | 'MINUTES' '(' Expression ')' // | 'SECONDS' '(' Expression ')' // | 'TIMEZONE' '(' Expression ')' // | 'TZ' '(' Expression ')' // | 'NOW' NIL // | 'UUID' NIL // | 'STRUUID' NIL // | 'MD5' '(' Expression ')' // | 'SHA1' '(' Expression ')' // | 'SHA256' '(' Expression ')' // | 'SHA384' '(' Expression ')' // | 'SHA512' '(' Expression ')' // | 'COALESCE' ExpressionList // | 'IF' '(' Expression ',' Expression ',' Expression ')' // | 'STRLANG' '(' Expression ',' Expression ')' // | 'STRDT' '(' Expression ',' Expression ')' // | 'sameTerm' '(' Expression ',' Expression ')' // | 'isIRI' '(' Expression ')' // | 'isURI' '(' Expression ')' // | 'isBLANK' '(' Expression ')' // | 'isLITERAL' '(' Expression ')' // | 'isNUMERIC' '(' Expression ')' // | RegexExpression // | ExistsFunc // | NotExistsFunc Str(Box), Lang(Box), Datatype(Box), Bound(Var), Iri(Box), Bnode(Box), Coalesce(ExpressionList), If(Box, Box, Box), StrLang(Box, Box), StrDt(Box, Box), SameTerm(Box, Box), IsIri(Box), IsBlank(Box), IsLiteral(Box), IsNumeric(Box), Exists(ExistsFunc), NotExists(NotExistsFunc), // TODO: Other functions } impl fmt::Display for BuiltInCall { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Self::Str(v) => write!(f, "STR({v})"), Self::Lang(v) => write!(f, "LANG({v})"), Self::Datatype(v) => write!(f, "DATATYPE({v})"), Self::Bound(v) => write!(f, "BOUND({v})"), Self::Iri(v) => write!(f, "IRI({v})"), Self::Bnode(v) => write!(f, "BNODE({v})"), Self::Coalesce(vs) => write!(f, "COALESCE{vs}"), Self::If(a, b, c) => write!(f, "IF({a}, {b}, {c})"), Self::StrLang(a, b) => write!(f, "STRLANG({a}, {b})"), Self::StrDt(a, b) => write!(f, "STRDT({a}, {b})"), Self::SameTerm(a, b) => write!(f, "sameTerm({a}, {b})"), Self::IsIri(e) => write!(f, "isIRI({e})"), Self::IsBlank(e) => write!(f, "isBlank({e})"), Self::IsLiteral(e) => write!(f, "isLiteral({e})"), Self::IsNumeric(e) => write!(f, "isNumeric({e})"), Self::Exists(e) => write!(f, "{e}"), Self::NotExists(e) => write!(f, "{e}"), } } } #[derive(Arbitrary)] struct ExistsFunc { // [125] ExistsFunc ::= 'EXISTS' GroupGraphPattern pattern: GroupGraphPattern, } impl fmt::Display for ExistsFunc { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "EXISTS {}", self.pattern) } } #[derive(Arbitrary)] struct NotExistsFunc { // [126] NotExistsFunc ::= 'NOT' 'EXISTS' GroupGraphPattern pattern: GroupGraphPattern, } impl fmt::Display for NotExistsFunc { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "NOT EXISTS {}", self.pattern) } } #[derive(Arbitrary)] struct IriOrFunction { // [128] iriOrFunction ::= iri ArgList? iri: Iri, // TODO args: Option, } impl fmt::Display for IriOrFunction { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.iri)?; // if let Some(args) = &self.args { // write!(f, "{args}")?; // } Ok(()) } } struct Literal { // [129] RDFLiteral ::= String ( LANGTAG | ( '^^' iri ) )? // [130] NumericLiteral ::= NumericLiteralUnsigned | NumericLiteralPositive | NumericLiteralNegative // [131] NumericLiteralUnsigned ::= INTEGER | DECIMAL | DOUBLE // [132] NumericLiteralPositive ::= INTEGER_POSITIVE | DECIMAL_POSITIVE | DOUBLE_POSITIVE // [133] NumericLiteralNegative ::= INTEGER_NEGATIVE | DECIMAL_NEGATIVE | DOUBLE_NEGATIVE // [134] BooleanLiteral ::= 'true' | 'false' value: &'static str, } impl Arbitrary<'_> for Literal { fn arbitrary(u: &mut Unstructured<'_>) -> Result { Ok(Self { value: u.choose(LITERALS.as_slice())?, }) } fn size_hint(depth: usize) -> (usize, Option) { ::size_hint(depth) } } impl fmt::Display for Literal { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", self.value) } } struct Iri { // [136] iri ::= IRIREF | PrefixedName value: u8, } impl Arbitrary<'_> for Iri { fn arbitrary(u: &mut Unstructured<'_>) -> Result { Ok(Self { value: u.int_in_range(1..=NUMBER_OF_NAMED_NODES)?, }) } fn size_hint(depth: usize) -> (usize, Option) { ::size_hint(depth) } } impl fmt::Display for Iri { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, " ", self.value) } }