Class: SPARQL::Algebra::Operator::Triple
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/triple.rb
Overview
Note:
This operator overlaps with RDF::Query::Pattern as used as an operand to a BGP.
The SPARQL triple operator.
If the 3-tuple (term1, term2, term3) is an RDF-star triple, the function returns this triple. If the 3-tuple is not an RDF-star triple, then the function raises an error.
[121] BuiltInCall ::= ... | 'TRIPLE' '(' Expression ',' Expression ',' Expression ')'
Constant Summary collapse
- NAME =
:triple
Instance Method Summary collapse
- #apply(subject, predicate, object, **options) ⇒ RDF::URI
-
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Methods included from Evaluatable
#evaluate, #memoize, #replace_aggregate!, #replace_vars!
Instance Method Details
#apply(subject, predicate, object, **options) ⇒ RDF::URI
35 36 37 38 39 |
# File 'lib/sparql/algebra/operator/triple.rb', line 35 def apply(subject, predicate, object, **) triple = RDF::Statement(subject, predicate, object) raise TypeError, "valid components, but got #{triple.inspect}" unless triple.valid? triple end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
46 47 48 |
# File 'lib/sparql/algebra/operator/triple.rb', line 46 def to_sparql(**) "TRIPLE(#{operands.to_sparql(delimiter: ', ', **)})" end |