Throw error if log_statement_stats is used with confliction options for

per-query stage stats.
This commit is contained in:
Bruce Momjian 2004-05-07 01:34:08 +00:00
parent 0bd61548ab
commit ae96e629b8
1 changed files with 48 additions and 5 deletions

View File

@ -10,7 +10,7 @@
* Written by Peter Eisentraut <peter_e@gmx.net>. * Written by Peter Eisentraut <peter_e@gmx.net>.
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/utils/misc/guc.c,v 1.202 2004/05/07 00:24:58 tgl Exp $ * $PostgreSQL: pgsql/src/backend/utils/misc/guc.c,v 1.203 2004/05/07 01:34:08 momjian Exp $
* *
*-------------------------------------------------------------------- *--------------------------------------------------------------------
*/ */
@ -103,6 +103,8 @@ static const char *assign_log_statement(const char *newval, bool doit,
static const char *assign_log_stmtlvl(int *var, const char *newval, static const char *assign_log_stmtlvl(int *var, const char *newval,
bool doit, GucSource source); bool doit, GucSource source);
static bool assign_phony_autocommit(bool newval, bool doit, GucSource source); static bool assign_phony_autocommit(bool newval, bool doit, GucSource source);
static bool assign_stage_log_stats(bool newval, bool doit, GucSource source);
static bool assign_log_stats(bool newval, bool doit, GucSource source);
/* /*
@ -577,7 +579,7 @@ static struct config_bool ConfigureNamesBool[] =
NULL NULL
}, },
&log_parser_stats, &log_parser_stats,
false, NULL, NULL false, assign_stage_log_stats, NULL
}, },
{ {
{"log_planner_stats", PGC_USERLIMIT, STATS_MONITORING, {"log_planner_stats", PGC_USERLIMIT, STATS_MONITORING,
@ -585,7 +587,7 @@ static struct config_bool ConfigureNamesBool[] =
NULL NULL
}, },
&log_planner_stats, &log_planner_stats,
false, NULL, NULL false, assign_stage_log_stats, NULL
}, },
{ {
{"log_executor_stats", PGC_USERLIMIT, STATS_MONITORING, {"log_executor_stats", PGC_USERLIMIT, STATS_MONITORING,
@ -593,7 +595,7 @@ static struct config_bool ConfigureNamesBool[] =
NULL NULL
}, },
&log_executor_stats, &log_executor_stats,
false, NULL, NULL false, assign_stage_log_stats, NULL
}, },
{ {
{"log_statement_stats", PGC_USERLIMIT, STATS_MONITORING, {"log_statement_stats", PGC_USERLIMIT, STATS_MONITORING,
@ -601,7 +603,7 @@ static struct config_bool ConfigureNamesBool[] =
NULL NULL
}, },
&log_statement_stats, &log_statement_stats,
false, NULL, NULL false, assign_log_stats, NULL
}, },
#ifdef BTREE_BUILD_STATS #ifdef BTREE_BUILD_STATS
{ {
@ -4709,4 +4711,45 @@ assign_phony_autocommit(bool newval, bool doit, GucSource source)
} }
static bool
assign_stage_log_stats(bool newval, bool doit, GucSource source)
{
if (newval)
{
if (log_statement_stats)
{
if (doit)
ereport(ERROR,
(errcode(ERRCODE_ERROR_IN_ASSIGNMENT),
errmsg("Can not enable parameter when \"log_statement_stats\" is true.")));
else
return false;
}
return true;
}
return true;
}
static bool
assign_log_stats(bool newval, bool doit, GucSource source)
{
if (newval)
{
if (log_parser_stats || log_planner_stats || log_executor_stats)
{
if (doit)
ereport(ERROR,
(errcode(ERRCODE_ERROR_IN_ASSIGNMENT),
errmsg("Can not enable \"log_statement_stats\" when \"log_parser_stats\",\n"
"\"log_planner_stats\", or \"log_executor_stats\" is true.")));
else
return false;
}
return true;
}
return true;
}
#include "guc-file.c" #include "guc-file.c"