Commit e9b64824 authored by Tom Lane's avatar Tom Lane

Improve comments for execExpr.c's isAssignmentIndirectionExpr().

I got confused about why this function doesn't need to recursively
search the expression tree for a CaseTestExpr node.  After figuring
that out, add a comment to save the next person some time.
parent 837255cc
...@@ -2443,14 +2443,14 @@ ExecInitArrayRef(ExprEvalStep *scratch, ArrayRef *aref, PlanState *parent, ...@@ -2443,14 +2443,14 @@ ExecInitArrayRef(ExprEvalStep *scratch, ArrayRef *aref, PlanState *parent,
* refassgnexpr is itself a FieldStore or ArrayRef that needs to * refassgnexpr is itself a FieldStore or ArrayRef that needs to
* obtain and modify the previous value of the array element or slice * obtain and modify the previous value of the array element or slice
* being replaced. If so, we have to extract that value from the * being replaced. If so, we have to extract that value from the
* array and pass it down via the CaseTextExpr mechanism. It's safe * array and pass it down via the CaseTestExpr mechanism. It's safe
* to reuse the CASE mechanism because there cannot be a CASE between * to reuse the CASE mechanism because there cannot be a CASE between
* here and where the value would be needed, and an array assignment * here and where the value would be needed, and an array assignment
* can't be within a CASE either. (So saving and restoring * can't be within a CASE either. (So saving and restoring
* innermost_caseval is just paranoia, but let's do it anyway.) * innermost_caseval is just paranoia, but let's do it anyway.)
* *
* Since fetching the old element might be a nontrivial expense, do it * Since fetching the old element might be a nontrivial expense, do it
* only if the argument appears to actually need it. * only if the argument actually needs it.
*/ */
if (isAssignmentIndirectionExpr(aref->refassgnexpr)) if (isAssignmentIndirectionExpr(aref->refassgnexpr))
{ {
...@@ -2506,10 +2506,16 @@ ExecInitArrayRef(ExprEvalStep *scratch, ArrayRef *aref, PlanState *parent, ...@@ -2506,10 +2506,16 @@ ExecInitArrayRef(ExprEvalStep *scratch, ArrayRef *aref, PlanState *parent,
/* /*
* Helper for preparing ArrayRef expressions for evaluation: is expr a nested * Helper for preparing ArrayRef expressions for evaluation: is expr a nested
* FieldStore or ArrayRef that might need the old element value passed down? * FieldStore or ArrayRef that needs the old element value passed down?
* *
* (We could use this in FieldStore too, but in that case passing the old * (We could use this in FieldStore too, but in that case passing the old
* value is so cheap there's no need.) * value is so cheap there's no need.)
*
* Note: it might seem that this needs to recurse, but it does not; the
* CaseTestExpr, if any, will be directly the arg or refexpr of the top-level
* node. Nested-assignment situations give rise to expression trees in which
* each level of assignment has its own CaseTestExpr, and the recursive
* structure appears within the newvals or refassgnexpr field.
*/ */
static bool static bool
isAssignmentIndirectionExpr(Expr *expr) isAssignmentIndirectionExpr(Expr *expr)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment