Class: SPARQL::Algebra::Operator::Seq
- Includes:
- Query
- Defined in:
- lib/sparql/algebra/operator/seq.rb
Overview
The SPARQL Property Path sequence (SequencePath) operator.
[90] PathSequence ::= PathEltOrInverse ( '/' PathEltOrInverse )*
Constant Summary collapse
- NAME =
:seq
Instance Attribute Summary
Attributes included from Query
Instance Method Summary collapse
-
#execute(queryable, **options) {|solution| ... } ⇒ Object
Join solution sets.
-
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Methods included from Query
#each_solution, #empty?, #failed?, #graph_name=, #matched?, #query_yields_boolean?, #query_yields_solutions?, #query_yields_statements?, #unshift, #variables
Instance Method Details
#execute(queryable, **options) {|solution| ... } ⇒ Object
Join solution sets
(path :x (seq :p :q) :y)
=> (join (bgp (:x :p ??1)) (bgp (??1 :q :y)))
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
# File 'lib/sparql/algebra/operator/seq.rb', line 41 def execute(queryable, **, &block) subject, object = [:subject], [:object] debug() {"Seq #{[subject, operands, object].to_sse}"} v = RDF::Query::Variable.new(distinguished: false) q1 = if operand(0).is_a?(RDF::Term) RDF::Query.new do |q| q.pattern [subject, operand(0), v] end else operand(0) end q2 = if operand(1).is_a?(RDF::Term) RDF::Query.new do |q| q.pattern [v, operand(1), object] end else operand(1) end left = queryable.query(q1, **.merge(object: v, depth: [:depth].to_i + 1)) #debug(options) {"(seq)=>(left) #{left.map(&:to_h).to_sse}"} right = queryable.query(q2, **.merge(subject: v, depth: [:depth].to_i + 1)) #debug(options) {"(seq)=>(right) #{right.map(&:to_h).to_sse}"} @solutions = RDF::Query::Solutions(left.map do |s1| right.map do |s2| s2.merge(s1) if s2.compatible?(s1) end end.flatten.compact).map do |solution| solution.bindings.delete(v.to_sym) solution end debug() {"(seq)=> #{@solutions.to_sxp}"} @solutions.each(&block) if block_given? @solutions end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
85 86 87 |
# File 'lib/sparql/algebra/operator/seq.rb', line 85 def to_sparql(**) '(' + operands.to_sparql(delimiter: '/', **) + ')' end |