Mutable<ILogicalExpression> lvm1 = ExpressionToolbox.findVariableExpression(aggregate.getExpressions().get(0));
if (lvm1 == null) {
return false;
}
VariableReferenceExpression vre1 = (VariableReferenceExpression) lvm1.getValue();
// UNNEST($v1, iterate($v0) )
AbstractLogicalOperator subplanOp2 = (AbstractLogicalOperator) subplanOp1.getInputs().get(0).getValue();
if (subplanOp2.getOperatorTag() != LogicalOperatorTag.UNNEST) {
return false;
}
UnnestOperator subplanUnnest = (UnnestOperator) subplanOp2;
// Check to see if the expression is the iterate operator.
ILogicalExpression logicalExpression2 = (ILogicalExpression) subplanUnnest.getExpressionRef().getValue();
if (logicalExpression2.getExpressionTag() != LogicalExpressionTag.FUNCTION_CALL) {
return false;
}
AbstractFunctionCallExpression functionCall2 = (AbstractFunctionCallExpression) logicalExpression2;
if (!functionCall2.getFunctionIdentifier().equals(BuiltinOperators.ITERATE.getFunctionIdentifier())) {
return false;
}
if (subplanUnnest.getVariable() != vre1.getVariableReference()) {
return false;
}
Mutable<ILogicalExpression> lvm2 = ExpressionToolbox.findVariableExpression(subplanUnnest.getExpressionRef());
if (lvm2 == null) {
return false;
}
VariableReferenceExpression vre2 = (VariableReferenceExpression) lvm2.getValue();
// NESTEDTUPLESOURCE
AbstractLogicalOperator subplanOp3 = (AbstractLogicalOperator) subplanOp2.getInputs().get(0).getValue();
if (subplanOp3.getOperatorTag() != LogicalOperatorTag.NESTEDTUPLESOURCE) {
return false;
}
// Ensure input is from a UNNEST operator.
AbstractLogicalOperator subplanInput = (AbstractLogicalOperator) subplan.getInputs().get(0).getValue();
if (subplanInput.getOperatorTag() != LogicalOperatorTag.ASSIGN) {
return false;
}
AssignOperator assign = (AssignOperator) subplanInput;
if (!assign.getVariables().contains(vre2.getVariableReference())) {
return false;
}
// Check to see if the expression is the iterate operator.
ILogicalExpression logicalExpression3 = (ILogicalExpression) assign.getExpressions().get(0).getValue();