Sha256: 98bffdc4495ccb5dbb7e133504b6436270f47f206d92dc0f00b1d28d7cedd824
Contents?: true
Size: 1.41 KB
Versions: 7
Compression:
Stored size: 1.41 KB
Contents
module SPARQL; module Algebra class Operator ## # The SPARQL GraphPattern `exprlist` operator. # # Used for filters with more than one expression. # # @example # (prefix ((: <http://example/>)) # (project (?v ?w) # (filter (exprlist (= ?v 2) (= ?w 3)) # (bgp # (triple ?s :p ?v) # (triple ?s :q ?w) # )))) # # @see https://www.w3.org/TR/sparql11-query/#evaluation class Exprlist < Operator include Evaluatable NAME = [:exprlist] ## # Returns `true` if all operands evaluate to `true`. # # Note that this operator operates on the effective boolean value # (EBV) of its operands. # # @example # # (exprlist (= 1 1) (!= 1 0)) # # @param [RDF::Query::Solution] bindings # a query solution containing zero or more variable bindings # @param [Hash{Symbol => Object}] options ({}) # options passed from query # @return [RDF::Literal::Boolean] `true` or `false` # @raise [TypeError] if the operands could not be coerced to a boolean literal def evaluate(bindings, **options) res = operands.all? {|op| boolean(op.evaluate(bindings, depth: options[:depth].to_i + 1, **options)).true? } RDF::Literal(res) # FIXME: error handling end end # Exprlist end # Operator end; end # SPARQL::Algebra
Version data entries
7 entries across 7 versions & 1 rubygems