mirror of
https://github.com/postgres/postgres.git
synced 2025-07-08 11:42:09 +03:00
Fix handling of redundant options with COPY for "freeze" and "header"
The handling of those options was inconsistent, as the processing used directly the value assigned to the option to check if it was redundant, leading to patterns like this one to succeed (note that false is specified first): COPY hoge to '/path/to/file/' (header off, header on); And the opposite would fail correctly (note that true is first here): COPY hoge to '/path/to/file/' (header on, header off); While on it, add some tests to check for all redundant patterns with the options of COPY. I have gone through the code and did not notice similar mistakes for other commands. "header" got it wrong sinceb63990c
, and "freeze" was wrong from the start as of8de72b6
. No backpatch is done per the lack of complaints. Reported-by: Rémi Lapeyre Discussion: https://postgr.es/m/20200929072433.GA15570@paquier.xyz Discussion: https://postgr.es/m/0B55BD07-83E4-439F-AACC-FA2D7CF50532@lenstra.fr
This commit is contained in:
@ -1159,6 +1159,8 @@ ProcessCopyOptions(ParseState *pstate,
|
||||
List *options)
|
||||
{
|
||||
bool format_specified = false;
|
||||
bool freeze_specified = false;
|
||||
bool header_specified = false;
|
||||
ListCell *option;
|
||||
|
||||
/* Support external use for option sanity checking */
|
||||
@ -1198,11 +1200,12 @@ ProcessCopyOptions(ParseState *pstate,
|
||||
}
|
||||
else if (strcmp(defel->defname, "freeze") == 0)
|
||||
{
|
||||
if (cstate->freeze)
|
||||
if (freeze_specified)
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_SYNTAX_ERROR),
|
||||
errmsg("conflicting or redundant options"),
|
||||
parser_errposition(pstate, defel->location)));
|
||||
freeze_specified = true;
|
||||
cstate->freeze = defGetBoolean(defel);
|
||||
}
|
||||
else if (strcmp(defel->defname, "delimiter") == 0)
|
||||
@ -1225,11 +1228,12 @@ ProcessCopyOptions(ParseState *pstate,
|
||||
}
|
||||
else if (strcmp(defel->defname, "header") == 0)
|
||||
{
|
||||
if (cstate->header_line)
|
||||
if (header_specified)
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_SYNTAX_ERROR),
|
||||
errmsg("conflicting or redundant options"),
|
||||
parser_errposition(pstate, defel->location)));
|
||||
header_specified = true;
|
||||
cstate->header_line = defGetBoolean(defel);
|
||||
}
|
||||
else if (strcmp(defel->defname, "quote") == 0)
|
||||
|
Reference in New Issue
Block a user