Class: Veritas::Optimizer::Relation::Operation::Reverse::OrderOperand
- Inherits:
-
Veritas::Optimizer::Relation::Operation::Reverse
- Object
- Veritas::Optimizer
- Unary
- Order
- Veritas::Optimizer::Relation::Operation::Reverse
- Veritas::Optimizer::Relation::Operation::Reverse::OrderOperand
- Defined in:
- lib/veritas/optimizer/relation/operation/reverse.rb
Overview
Optimize when the operand is an Order
Constant Summary
Constants inherited from Veritas::Optimizer
Instance Attribute Summary
Attributes inherited from Unary
Attributes included from Function::Unary
Attributes inherited from Veritas::Optimizer
Instance Method Summary collapse
-
#optimizable? ⇒ Boolean
private
Test if the operand is an Order.
-
#optimize ⇒ Order
private
Flatten Reverse operation and Order operand into an Order.
Methods inherited from Unary
Methods included from Function::Unary
Methods inherited from Veritas::Optimizer
Constructor Details
This class inherits a constructor from Veritas::Optimizer::Relation::Operation::Unary
Instance Method Details
#optimizable? ⇒ Boolean
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Test if the operand is an Order
42 43 44 |
# File 'lib/veritas/optimizer/relation/operation/reverse.rb', line 42 def optimizable? operand.kind_of?(Veritas::Relation::Operation::Order) end |
#optimize ⇒ Order
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Flatten Reverse operation and Order operand into an Order
51 52 53 |
# File 'lib/veritas/optimizer/relation/operation/reverse.rb', line 51 def optimize operand.operand.sort_by { operation.directions } end |