Class: SPARQL::Algebra::Operator::IsLiteral
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/is_literal.rb
Overview
The SPARQL isLiteral operator.
[121] BuiltInCall ::= ... | 'isLiteral' '(' Expression ')'
Constant Summary collapse
- NAME =
:isLiteral
Instance Method Summary collapse
-
#apply(term, **options) ⇒ RDF::Literal::Boolean
Returns
trueif the operand is anRDF::Literal,falseotherwise. -
#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(term, **options) ⇒ RDF::Literal::Boolean
Returns true if the operand is an RDF::Literal, false
otherwise.
35 36 37 38 39 40 41 |
# File 'lib/sparql/algebra/operator/is_literal.rb', line 35 def apply(term, **) case term when RDF::Literal then RDF::Literal::TRUE when RDF::Term then RDF::Literal::FALSE else raise TypeError, "expected an RDF::Term, but got #{term.inspect}" end end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
48 49 50 |
# File 'lib/sparql/algebra/operator/is_literal.rb', line 48 def to_sparql(**) "isLiteral(" + operands.first.to_sparql(**) + ")" end |