Class: SPARQL::Algebra::Operator::SameTerm
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/same_term.rb
Overview
The SPARQL sameTerm operator.
[121] BuiltInCall ::= ... | 'sameTerm' '(' Expression ',' Expression ')'
Constant Summary collapse
- NAME =
:sameTerm
Instance Method Summary collapse
-
#apply(term1, term2, **options) ⇒ RDF::Literal::Boolean
Returns
trueif the operands are the same RDF term; returnsfalseotherwise. -
#optimize(**options) ⇒ SameTerm
Returns an optimized version of this expression.
-
#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(term1, term2, **options) ⇒ RDF::Literal::Boolean
Returns true if the operands are the same RDF term; returns
false otherwise.
38 39 40 |
# File 'lib/sparql/algebra/operator/same_term.rb', line 38 def apply(term1, term2, **) RDF::Literal(term1.eql?(term2)) end |
#optimize(**options) ⇒ SameTerm
Returns an optimized version of this expression.
Return true if variable operand1 is a bound variable and equals operand2
49 50 51 52 53 54 55 |
# File 'lib/sparql/algebra/operator/same_term.rb', line 49 def optimize(**) if operand(0).is_a?(Variable) && operand(0).bound? && operand(0).eql?(operand(1)) RDF::Literal::TRUE else super # @see Operator#optimize! end end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
62 63 64 |
# File 'lib/sparql/algebra/operator/same_term.rb', line 62 def to_sparql(**) "sameTerm(#{operands.to_sparql(delimiter: ', ', **)})" end |