Class: SPARQL::Algebra::Operator::Divide
- Inherits:
-
Binary
- Object
- SPARQL::Algebra::Operator
- Binary
- SPARQL::Algebra::Operator::Divide
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/divide.rb
Overview
The SPARQL numeric divide
operator.
[117] MultiplicativeExpression::= UnaryExpression ( ‘’ UnaryExpression | ‘/’ UnaryExpression )
Constant Summary collapse
- NAME =
[:'/', :divide]
Constants inherited from Binary
Constants inherited from SPARQL::Algebra::Operator
Constants included from Expression
Instance Attribute Summary
Attributes inherited from SPARQL::Algebra::Operator
Instance Method Summary collapse
-
#apply(left, right, **options) ⇒ RDF::Literal::Numeric
Returns the arithmetic quotient of the operands.
-
#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 Binary
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::Binary
Instance Method Details
#apply(left, right, **options) ⇒ RDF::Literal::Numeric
Returns the arithmetic quotient of the operands.
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/sparql/algebra/operator/divide.rb', line 39 def apply(left, right, **) case when left.is_a?(RDF::Literal::Numeric) && right.is_a?(RDF::Literal::Numeric) # For xsd:decimal and xsd:integer operands, if the divisor is # (positive or negative) zero, an error is raised. raise ZeroDivisionError, "divided by #{right}" if left.is_a?(RDF::Literal::Decimal) && right.zero? # As a special case, if the types of both operands are # xsd:integer, then the return type is xsd:decimal. if left.is_a?(RDF::Literal::Integer) && right.is_a?(RDF::Literal::Integer) RDF::Literal(left.to_d / right.to_d) else left / right end else raise TypeError, "expected two RDF::Literal::Numeric operands, but got #{left.inspect} and #{right.inspect}" end end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
62 63 64 |
# File 'lib/sparql/algebra/operator/divide.rb', line 62 def to_sparql(**) "(#{operands.first.to_sparql(**)} / #{operands.last.to_sparql(**)})" end |