OmniSciDB  b24e664e58
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor Class Reference
+ Inheritance diagram for anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor:
+ Collaboration diagram for anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor:

Public Member Functions

 RexWindowFuncReplacementVisitor (std::unique_ptr< const RexScalar > replacement_rex)
 
 ~RexWindowFuncReplacementVisitor ()
 
- Public Member Functions inherited from RexVisitorBase< std::unique_ptr< const RexScalar > >
virtual std::unique_ptr< const
RexScalar
visit (const RexScalar *rex_scalar) const
 

Protected Member Functions

RetType visitOperator (const RexOperator *rex_operator) const final
 
RetType visitCase (const RexCase *rex_case) const final
 
- Protected Member Functions inherited from RexDeepCopyVisitor
RetType visitInput (const RexInput *input) const override
 
RetType visitLiteral (const RexLiteral *literal) const override
 
RetType visitSubQuery (const RexSubQuery *subquery) const override
 
RetType visitRef (const RexRef *ref) const override
 
RetType visitOperator (const RexOperator *rex_operator) const override
 
RetType visitWindowFunctionOperator (const RexWindowFunctionOperator *rex_window_function_operator) const
 
RetType visitCase (const RexCase *rex_case) const override
 

Private Member Functions

bool should_replace_operand (const RexScalar *rex) const
 

Private Attributes

std::unique_ptr< const RexScalarreplacement_rex_
 

Additional Inherited Members

- Protected Types inherited from RexDeepCopyVisitor
using RetType = std::unique_ptr< const RexScalar >
 

Detailed Description

Replaces the first occurrence of a WindowFunctionOperator rex with the provided replacement_rex. Typically used for splitting a complex rex into two simpler rexes, and forwarding one of the rexes to a later node. The forwarded rex is then replaced with a RexInput using this visitor. Note that for window function replacement, the overloads in this visitor must match the overloads in the detection visitor above, to ensure a detected window function expression is properly replaced.

Definition at line 1545 of file RelAlgAbstractInterpreter.cpp.

Constructor & Destructor Documentation

anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor::RexWindowFuncReplacementVisitor ( std::unique_ptr< const RexScalar replacement_rex)
inline

Definition at line 1547 of file RelAlgAbstractInterpreter.cpp.

1548  : replacement_rex_(std::move(replacement_rex)) {}
anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor::~RexWindowFuncReplacementVisitor ( )
inline

Definition at line 1550 of file RelAlgAbstractInterpreter.cpp.

References CHECK().

1550 { CHECK(replacement_rex_ == nullptr); }
CHECK(cgen_state)

+ Here is the call graph for this function:

Member Function Documentation

bool anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor::should_replace_operand ( const RexScalar rex) const
inlineprivate

Definition at line 1600 of file RelAlgAbstractInterpreter.cpp.

References anonymous_namespace{RelAlgAbstractInterpreter.cpp}::anonymous_namespace{RelAlgAbstractInterpreter.cpp}::is_window_function_operator().

+ Here is the call graph for this function:

RetType anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor::visitCase ( const RexCase rex_case) const
inlinefinalprotectedvirtual

Implements RexVisitorBase< std::unique_ptr< const RexScalar > >.

Definition at line 1578 of file RelAlgAbstractInterpreter.cpp.

References RexCase::branchCount(), RexCase::getElse(), RexCase::getThen(), and RexCase::getWhen().

1578  {
1579  if (should_replace_operand(rex_case)) {
1580  return std::move(replacement_rex_);
1581  }
1582 
1583  std::vector<std::pair<RetType, RetType>> new_pair_list;
1584  for (size_t i = 0; i < rex_case->branchCount(); ++i) {
1585  auto when_operand = rex_case->getWhen(i);
1586  auto then_operand = rex_case->getThen(i);
1587  new_pair_list.emplace_back(
1588  should_replace_operand(when_operand) ? std::move(replacement_rex_)
1589  : visit(when_operand),
1590  should_replace_operand(then_operand) ? std::move(replacement_rex_)
1591  : visit(then_operand));
1592  }
1593  auto new_else = should_replace_operand(rex_case->getElse())
1594  ? std::move(replacement_rex_)
1595  : visit(rex_case->getElse());
1596  return std::make_unique<RexCase>(new_pair_list, new_else);
1597  }
const RexScalar * getThen(const size_t idx) const
const RexScalar * getElse() const
const RexScalar * getWhen(const size_t idx) const
virtual std::unique_ptr< const RexScalar > visit(const RexScalar *rex_scalar) const
Definition: RexVisitor.h:27
size_t branchCount() const

+ Here is the call graph for this function:

RetType anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor::visitOperator ( const RexOperator rex_operator) const
inlinefinalprotectedvirtual

Implements RexVisitorBase< std::unique_ptr< const RexScalar > >.

Definition at line 1553 of file RelAlgAbstractInterpreter.cpp.

1553  {
1554  if (should_replace_operand(rex_operator)) {
1555  return std::move(replacement_rex_);
1556  }
1557 
1558  const auto rex_window_function_operator =
1559  dynamic_cast<const RexWindowFunctionOperator*>(rex_operator);
1560  if (rex_window_function_operator) {
1561  // Deep copy the embedded window function operator
1562  return visitWindowFunctionOperator(rex_window_function_operator);
1563  }
1564 
1565  const size_t operand_count = rex_operator->size();
1566  std::vector<RetType> new_opnds;
1567  for (size_t i = 0; i < operand_count; ++i) {
1568  const auto operand = rex_operator->getOperand(i);
1569  if (should_replace_operand(operand)) {
1570  new_opnds.push_back(std::move(replacement_rex_));
1571  } else {
1572  new_opnds.emplace_back(visit(rex_operator->getOperand(i)));
1573  }
1574  }
1575  return rex_operator->getDisambiguated(new_opnds);
1576  }
size_t size() const
const RexScalar * getOperand(const size_t idx) const
RetType visitWindowFunctionOperator(const RexWindowFunctionOperator *rex_window_function_operator) const
Definition: RexVisitor.h:168
virtual std::unique_ptr< const RexOperator > getDisambiguated(std::vector< std::unique_ptr< const RexScalar >> &operands) const
virtual std::unique_ptr< const RexScalar > visit(const RexScalar *rex_scalar) const
Definition: RexVisitor.h:27

Member Data Documentation

std::unique_ptr<const RexScalar> anonymous_namespace{RelAlgAbstractInterpreter.cpp}::RexWindowFuncReplacementVisitor::replacement_rex_
mutableprivate

Definition at line 1604 of file RelAlgAbstractInterpreter.cpp.


The documentation for this class was generated from the following file: