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