module SPARQL; module Algebra class Operator ## # The SPARQL logical `year` operator. # # Returns the year part of `arg` as an integer. # # [121] BuiltInCall ::= ... | 'YEAR' '(' Expression ')' # # @example SPARQL Grammar # PREFIX : # SELECT ?s (YEAR(?date) AS ?x) WHERE { # ?s :date ?date # } # # @example SSE # (prefix # ((: )) # (project (?s ?x) # (extend ((?x (year ?date))) # (bgp (triple ?s :date ?date))))) # # @see https://www.w3.org/TR/sparql11-query/#func-year class Year < Operator::Unary include Evaluatable NAME = :year ## # Returns the year part of arg as an integer. # # @param [RDF::Literal] operand # the operand # @return [RDF::Literal] # @raise [TypeError] if the operand is not a simple literal def apply(operand, **options) raise TypeError, "expected an RDF::Literal::DateTime, but got #{operand.inspect}" unless operand.is_a?(RDF::Literal::DateTime) RDF::Literal(operand.object.year) end ## # # Returns a partial SPARQL grammar for this operator. # # @return [String] def to_sparql(**options) "YEAR(#{operands.last.to_sparql(**options)})" end end # Year end # Operator end; end # SPARQL::Algebra