Class: SPARQL::Algebra::Operator::IsBlank
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/is_blank.rb
Overview
The SPARQL isBlank operator.
[121] BuiltInCall ::= ... | 'isBlank' '(' Expression ')'
Constant Summary collapse
- NAME =
:isBlank
Instance Method Summary collapse
-
#apply(term, **options) ⇒ RDF::Literal::Boolean
Returns
trueif the operand is anRDF::Node,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::Node, false otherwise.
34 35 36 37 38 39 40 |
# File 'lib/sparql/algebra/operator/is_blank.rb', line 34 def apply(term, **) case term when RDF::Node 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.
47 48 49 |
# File 'lib/sparql/algebra/operator/is_blank.rb', line 47 def to_sparql(**) "isBlank(" + operands.first.to_sparql(**) + ")" end |