Class: SPARQL::Algebra::Operator::Timezone
- Inherits:
-
Unary
- Object
- SPARQL::Algebra::Operator
- Unary
- SPARQL::Algebra::Operator::Timezone
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/timezone.rb
Overview
The SPARQL logical timezone
operator.
Returns the timezone part of arg
as an xsd:dayTimeDuration. Raises an error if there is no timezone.
[121] BuiltInCall ::= … | ‘TIMEZONE’ ‘(’ Expression ‘)’
Constant Summary collapse
- NAME =
:timezone
Constants inherited from Unary
Constants inherited from SPARQL::Algebra::Operator
Constants included from Expression
Instance Attribute Summary
Attributes inherited from SPARQL::Algebra::Operator
Instance Method Summary collapse
-
#apply(operand, **options) ⇒ RDF::Literal::Temporal
Returns the timezone part of arg as an xsd:dayTimeDuration.
-
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Methods included from Evaluatable
#evaluate, #memoize, #replace_aggregate!, #replace_vars!
Methods inherited from Unary
Methods inherited from SPARQL::Algebra::Operator
#aggregate?, arity, #base_uri, base_uri, base_uri=, #bind, #boolean, #constant?, #deep_dup, #each_descendant, #eql?, #evaluatable?, evaluate, #executable?, #first_ancestor, for, #initialize, #inspect, #ndvars, #node?, #operand, #optimize, #optimize!, #parent, #parent=, #prefixes, prefixes, prefixes=, #rewrite, #to_binary, to_sparql, #to_sxp, #to_sxp_bin, #validate!, #variable?, #variables, #vars
Methods included from Expression
cast, #constant?, #evaluate, extension, extension?, extensions, for, #invalid?, new, #node?, open, #optimize, #optimize!, parse, register_extension, #to_sxp_bin, #valid?, #validate!, #variable?
Constructor Details
This class inherits a constructor from SPARQL::Algebra::Operator::Unary
Instance Method Details
#apply(operand, **options) ⇒ RDF::Literal::Temporal
Returns the timezone part of arg as an xsd:dayTimeDuration. Raises an error if there is no timezone.
This function corresponds to fn:timezone-from-dateTime except for the treatment of literals with no timezone.
38 39 40 41 42 |
# File 'lib/sparql/algebra/operator/timezone.rb', line 38 def apply(operand, **) raise TypeError, "expected an RDF::Literal::Temporal, but got #{operand.inspect}" unless operand.is_a?(RDF::Literal::Temporal) raise TypeError, "literal has no timezone" unless res = operand.timezone res end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
49 50 51 |
# File 'lib/sparql/algebra/operator/timezone.rb', line 49 def to_sparql(**) "TIMEZONE(" + operands.to_sparql(**) + ")" end |