Sha256: 7eddb69c505c238ccc56b7b5ed95668b102ad4939c2749d9b3cb68f67d92d9c2

Contents?: true

Size: 1.34 KB

Versions: 7

Compression:

Stored size: 1.34 KB

Contents

module SPARQL; module Algebra
  class Operator
    ##
    # The SPARQL logical `exists` operator.
    #
    # @example
    #    (prefix ((ex: <http://www.example.org/>))
    #      (filter (exists
    #                 (filter (notexists (bgp (triple ?s ?p ex:o2)))
    #                   (bgp (triple ?s ?p ex:o1))))
    #        (bgp (triple ?s ?p ex:o))))
    #
    # @see http://www.w3.org/TR/sparql11-query/#func-abs
    # @see http://www.w3.org/TR/xpath-functions/#func-abs
    class NotExists < Operator::Unary
      include Evaluatable

      NAME = [:notexists]

      ##
      # Exvaluating this operator executes the query in the first operator passing in each existing bindings.
      #
      # @param  [RDF::Query::Solution] bindings
      #   a query solution containing zero or more variable bindings
      # @param [Hash{Symbol => Object}] options ({})
      #   options passed from query
      # @option options[RDF::Queryable] queryable
      #   queryable to execute, using bindings as an initial solution.
      # @return [RDF::Literal::Boolean] `true` or `false`
      def evaluate(bindings, options = {})
        solutions = RDF::Query::Solutions(bindings)
        queryable = options[:queryable]
        operand(0).execute(queryable, options.merge(solutions: solutions)).empty?
      end
    end # NotExists
  end # Operator
end; end # SPARQL::Algebra

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
sparql-1.99.1 lib/sparql/algebra/operator/notexists.rb
sparql-1.1.9.1 lib/sparql/algebra/operator/notexists.rb
sparql-1.99.0 lib/sparql/algebra/operator/notexists.rb
sparql-1.1.9 lib/sparql/algebra/operator/notexists.rb
sparql-1.1.8 lib/sparql/algebra/operator/notexists.rb
sparql-1.1.7 lib/sparql/algebra/operator/notexists.rb
sparql-1.1.6 lib/sparql/algebra/operator/notexists.rb