diff options
| author | Fujii Masao <fujii@postgresql.org> | 2014-07-10 14:27:54 +0900 | 
|---|---|---|
| committer | Fujii Masao <fujii@postgresql.org> | 2014-07-10 14:27:54 +0900 | 
| commit | 5b214c5dd1de37764797b3fb9164af3c885a7b86 (patch) | |
| tree | 2bfde2150e2abaf04fe947f13843c6c8117f3d6c /src | |
| parent | b043985b7aaf62f6978a0c567c8340ad9cf1ad67 (diff) | |
Add new ECHO mode 'errors' that displays only failed commands in psql.
When the psql variable ECHO is set to 'erros', only failed SQL commands
are printed to standard error output. Also this patch adds -b option into psql.
This is equivalent to setting the variable ECHO to 'errors'.
Pavel Stehule, reviewed by FabrÃzio de Royes Mello, Samrat Revagade,
Kumar Rajeev Rastogi, Abhijit Menon-Sen, and me.
Diffstat (limited to 'src')
| -rw-r--r-- | src/bin/psql/common.c | 3 | ||||
| -rw-r--r-- | src/bin/psql/help.c | 1 | ||||
| -rw-r--r-- | src/bin/psql/settings.h | 1 | ||||
| -rw-r--r-- | src/bin/psql/startup.c | 8 | 
4 files changed, 12 insertions, 1 deletions
| diff --git a/src/bin/psql/common.c b/src/bin/psql/common.c index c08c81366d1..676e2680af6 100644 --- a/src/bin/psql/common.c +++ b/src/bin/psql/common.c @@ -995,6 +995,9 @@ SendQuery(const char *query)  		results = NULL;			/* PQclear(NULL) does nothing */  	} +	if (!OK && pset.echo == PSQL_ECHO_ERRORS) +		psql_error("STATEMENT:  %s\n", query); +  	/* If we made a temporary savepoint, possibly release/rollback */  	if (on_error_rollback_savepoint)  	{ diff --git a/src/bin/psql/help.c b/src/bin/psql/help.c index 3aa3c169c23..f8f000fb50f 100644 --- a/src/bin/psql/help.c +++ b/src/bin/psql/help.c @@ -87,6 +87,7 @@ usage(void)  	printf(_("\nInput and output options:\n"));  	printf(_("  -a, --echo-all           echo all input from script\n")); +	printf(_("  -b, --echo-errors        echo failed commands\n"));  	printf(_("  -e, --echo-queries       echo commands sent to server\n"));  	printf(_("  -E, --echo-hidden        display queries that internal commands generate\n"));  	printf(_("  -L, --log-file=FILENAME  send session log to file\n")); diff --git a/src/bin/psql/settings.h b/src/bin/psql/settings.h index 0a60e6817b2..453d6c889df 100644 --- a/src/bin/psql/settings.h +++ b/src/bin/psql/settings.h @@ -31,6 +31,7 @@ typedef enum  {  	PSQL_ECHO_NONE,  	PSQL_ECHO_QUERIES, +	PSQL_ECHO_ERRORS,  	PSQL_ECHO_ALL  } PSQL_ECHO; diff --git a/src/bin/psql/startup.c b/src/bin/psql/startup.c index 45653a15a80..5a397e8d550 100644 --- a/src/bin/psql/startup.c +++ b/src/bin/psql/startup.c @@ -354,6 +354,7 @@ parse_psql_options(int argc, char *argv[], struct adhoc_opts * options)  		{"command", required_argument, NULL, 'c'},  		{"dbname", required_argument, NULL, 'd'},  		{"echo-queries", no_argument, NULL, 'e'}, +		{"echo-errors", no_argument, NULL, 'b'},  		{"echo-hidden", no_argument, NULL, 'E'},  		{"file", required_argument, NULL, 'f'},  		{"field-separator", required_argument, NULL, 'F'}, @@ -391,7 +392,7 @@ parse_psql_options(int argc, char *argv[], struct adhoc_opts * options)  	memset(options, 0, sizeof *options); -	while ((c = getopt_long(argc, argv, "aAc:d:eEf:F:h:HlL:no:p:P:qR:sStT:U:v:VwWxXz?01", +	while ((c = getopt_long(argc, argv, "aAbc:d:eEf:F:h:HlL:no:p:P:qR:sStT:U:v:VwWxXz?01",  							long_options, &optindex)) != -1)  	{  		switch (c) @@ -402,6 +403,9 @@ parse_psql_options(int argc, char *argv[], struct adhoc_opts * options)  			case 'A':  				pset.popt.topt.format = PRINT_UNALIGNED;  				break; +			case 'b': +				SetVariable(pset.vars, "ECHO", "errors"); +				break;  			case 'c':  				options->action_string = pg_strdup(optarg);  				if (optarg[0] == '\\') @@ -720,6 +724,8 @@ echo_hook(const char *newval)  		pset.echo = PSQL_ECHO_NONE;  	else if (strcmp(newval, "queries") == 0)  		pset.echo = PSQL_ECHO_QUERIES; +	else if (strcmp(newval, "errors") == 0) +		pset.echo = PSQL_ECHO_ERRORS;  	else if (strcmp(newval, "all") == 0)  		pset.echo = PSQL_ECHO_ALL;  	else | 
