diff options
| author | Tom Lane <tgl@sss.pgh.pa.us> | 2021-10-11 11:56:52 -0400 | 
|---|---|---|
| committer | Tom Lane <tgl@sss.pgh.pa.us> | 2021-10-11 11:56:52 -0400 | 
| commit | 39ae0ef8561362304ee512963aa51d5a705e5616 (patch) | |
| tree | ed56fe38439a6c87c84eed03420e194b237d5e5c /src | |
| parent | 68f7c4b57a27dbcd3e93ba3ff7b0b49664b25e09 (diff) | |
Fix EXPLAIN of SEARCH BREADTH FIRST queries some more.
Commit 3f50b8263 had an oversight: formerly, to deparse expressions
attached to a plan node, it was only necessary to update the
deparse_namespace ancestors list alongside calling set_deparse_plan.
Now it's necessary to update the ancestors list *first*, because
set_deparse_plan consults it, and one call site got that wrong.
This error was masked in most cases because explain.c uses just one
List object for the ancestors list, updating it in-place as the plan
is scanned, so that we accidentally had the right List assigned to
dpns->ancestors before it was needed.  It would fail only if a
WorkTableScan node were the first one that we tried to deparse a
subexpression of.
Per report from Markus Winand.  Like the previous patch,
back-patch to v14.
Discussion: https://postgr.es/m/648B0505-AA57-42C2-A2DA-E551DE46FA15@winand.at
Diffstat (limited to 'src')
| -rw-r--r-- | src/backend/utils/adt/ruleutils.c | 4 | 
1 files changed, 2 insertions, 2 deletions
| diff --git a/src/backend/utils/adt/ruleutils.c b/src/backend/utils/adt/ruleutils.c index b15bd81b9ca..1bb25738a52 100644 --- a/src/backend/utils/adt/ruleutils.c +++ b/src/backend/utils/adt/ruleutils.c @@ -3681,8 +3681,8 @@ set_deparse_context_plan(List *dpcontext, Plan *plan, List *ancestors)  	dpns = (deparse_namespace *) linitial(dpcontext);  	/* Set our attention on the specific plan node passed in */ -	set_deparse_plan(dpns, plan);  	dpns->ancestors = ancestors; +	set_deparse_plan(dpns, plan);  	return dpcontext;  } @@ -4836,7 +4836,7 @@ get_rtable_name(int rtindex, deparse_context *context)   * of a given Plan node   *   * This sets the plan, outer_plan, inner_plan, outer_tlist, inner_tlist, - * and index_tlist fields.  Caller is responsible for adjusting the ancestors + * and index_tlist fields.  Caller must already have adjusted the ancestors   * list if necessary.  Note that the rtable, subplans, and ctes fields do   * not need to change when shifting attention to different plan nodes in a   * single plan tree. | 
