mirror of
https://github.com/postgres/postgres.git
synced 2025-06-14 18:42:34 +03:00
Export ExplainBeginOutput() and ExplainEndOutput() for auto_explain.
Without these functions, anyone outside of explain.c can't actually use ExplainPrintPlan, because the ExplainState won't be initialized properly. The user-visible result of this was a crash when using auto_explain with the JSON output format. Report by Euler Taveira de Oliveira. Analysis by Tom Lane. Patch by me.
This commit is contained in:
@ -6,7 +6,7 @@
|
||||
* Copyright (c) 2008-2009, PostgreSQL Global Development Group
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/contrib/auto_explain/auto_explain.c,v 1.8 2009/12/11 01:33:35 adunstan Exp $
|
||||
* $PostgreSQL: pgsql/contrib/auto_explain/auto_explain.c,v 1.9 2009/12/12 00:35:33 rhaas Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -223,7 +223,9 @@ explain_ExecutorEnd(QueryDesc *queryDesc)
|
||||
es.verbose = auto_explain_log_verbose;
|
||||
es.format = auto_explain_log_format;
|
||||
|
||||
ExplainBeginOutput(&es);
|
||||
ExplainPrintPlan(&es, queryDesc);
|
||||
ExplainEndOutput(&es);
|
||||
|
||||
/* Remove last line break */
|
||||
if (es.str->len > 0 && es.str->data[es.str->len - 1] == '\n')
|
||||
|
Reference in New Issue
Block a user