Commit 6338fa3e authored by Tom Lane's avatar Tom Lane

Avoid platform-specific null pointer dereference in psql.

POSIX permits getopt() to advance optind beyond argc when the last
argv entry is an option that requires an argument and hasn't got one.
It seems that no major platforms actually do that, but musl does,
so that something like "psql -f" would crash with that libc.
Add a check that optind is in range before trying to look at the
possibly-bogus option.

Report and fix by Quentin Rameau.  Back-patch to all supported
branches.

Discussion: https://postgr.es/m/20190825100617.GA6087@fifth.space
parent faee5a12
...@@ -666,15 +666,18 @@ parse_psql_options(int argc, char *argv[], struct adhoc_opts *options) ...@@ -666,15 +666,18 @@ parse_psql_options(int argc, char *argv[], struct adhoc_opts *options)
options->single_txn = true; options->single_txn = true;
break; break;
case '?': case '?':
/* Actual help option given */ if (optind <= argc &&
if (strcmp(argv[optind - 1], "-?") == 0) strcmp(argv[optind - 1], "-?") == 0)
{ {
/* actual help option given */
usage(NOPAGER); usage(NOPAGER);
exit(EXIT_SUCCESS); exit(EXIT_SUCCESS);
} }
/* unknown option reported by getopt */
else else
{
/* getopt error (unknown option or missing argument) */
goto unknown_option; goto unknown_option;
}
break; break;
case 1: case 1:
{ {
......
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