help.c 9.6 KB
Newer Older
1 2 3 4 5 6 7 8 9
#include <config.h>
#include <c.h>
#include "help.h"

#include <stdio.h>
#include <stdlib.h>
#include <signal.h>

#ifndef WIN32
B
Bruce Momjian 已提交
10
#include <sys/ioctl.h>			/* for ioctl() */
11
#ifdef HAVE_PWD_H
B
Bruce Momjian 已提交
12
#include <pwd.h>				/* for getpwuid() */
13
#endif
B
Bruce Momjian 已提交
14 15
#include <sys/types.h>			/* (ditto) */
#include <unistd.h>				/* for getuid() */
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
#else
#define strcasecmp(x,y) stricmp(x,y)
#define popen(x,y) _popen(x,y)
#define pclose(x) _pclose(x)
#endif

#include <pqsignal.h>
#include <libpq-fe.h>

#include "settings.h"
#include "common.h"
#include "sql_help.h"


/*
 * usage
 *
33
 * print out command line arguments
34 35 36
 */
#define ON(var) (var ? "on" : "off")

B
Bruce Momjian 已提交
37 38
void
usage(void)
39
{
B
Bruce Momjian 已提交
40 41 42
	const char *env;
	const char *user;

43
#ifndef WIN32
B
Bruce Momjian 已提交
44 45
	struct passwd *pw = NULL;

46 47
#endif

B
Bruce Momjian 已提交
48 49 50 51
	/* Find default user, in case we need it. */
	user = getenv("USER");
	if (!user)
	{
52
#ifndef WIN32
B
Bruce Momjian 已提交
53 54 55 56 57 58 59 60
		pw = getpwuid(getuid());
		if (pw)
			user = pw->pw_name;
		else
		{
			perror("getpwuid()");
			exit(EXIT_FAILURE);
		}
61
#else
B
Bruce Momjian 已提交
62
		user = "?";
63
#endif
B
Bruce Momjian 已提交
64
	}
65

66 67 68 69 70 71 72
/* If this " is the start of the string then it ought to end there to fit in 80 columns >> " */
    puts(  "This is psql, the PostgreSQL interactive terminal.");
	puts(  "\nUsage:");
    puts(  "  psql [options] [dbname [username]]");
    puts(  "\nOptions:");
	puts(  "  -A              Unaligned table output mode (-P format=unaligned");
	puts(  "  -c query        Run only single query (or slash command) and exit");
B
Bruce Momjian 已提交
73 74 75 76 77

	/* Display default database */
	env = getenv("PGDATABASE");
	if (!env)
		env = user;
78
	printf("  -d dbname       Specify database name to connect to (default: %s)\n", env);
B
Bruce Momjian 已提交
79

80 81 82 83
	puts(  "  -e              Echo all input in non-interactive mode");
	puts(  "  -E              Display queries that internal commands generate");
	puts(  "  -f filename     Execute queries from file, then exit");
	puts(  "  -F sep          Set field separator (default: \"" DEFAULT_FIELD_SEP "\") (-P fieldsep=)");
B
Bruce Momjian 已提交
84 85 86

	/* Display default host */
	env = getenv("PGHOST");
87
	printf("  -h host         Specify database server host (default: ");
B
Bruce Momjian 已提交
88
	if (env)
89
		fputs(env, stdout);
B
Bruce Momjian 已提交
90
	else
91 92
		fputs("domain socket", stdout);
	puts(")");
B
Bruce Momjian 已提交
93

94 95 96 97
	puts(  "  -H              HTML table output mode (-P format=html)");
	puts(  "  -l              List available databases, then exit");
	puts(  "  -n              Do not use readline or history");
	puts(  "  -o filename     Send query output to filename (or |pipe)");
B
Bruce Momjian 已提交
98 99 100

	/* Display default port */
	env = getenv("PGPORT");
101 102
	printf("  -p port         Specify database server port (default: %s)\n",
           env ? env : "hardwired");
B
Bruce Momjian 已提交
103

104 105 106 107 108 109
	puts(  "  -P var[=arg]    Set printing option 'var' to 'arg' (see \\pset command)");
	puts(  "  -q              Run quietly (no messages, only query output)");
	puts(  "  -s              Single step mode (confirm each query)");
	puts(  "  -S              Single line mode (newline terminates query)");
	puts(  "  -t              Don't print headings and row count (-P tuples_only)");
	puts(  "  -T text         Set HTML table tag options (width, border) (-P tableattr=)");
B
Bruce Momjian 已提交
110 111 112 113 114

	/* Display default user */
	env = getenv("PGUSER");
	if (!env)
		env = user;
115
	printf("  -U [username]   Specifiy username, \"?\"=prompt (default user: %s)\n", env);
B
Bruce Momjian 已提交
116

117 118 119 120
	puts(  "  -x              Turn on expanded table output (-P expanded)");
	puts(  "  -v name=val     Set psql variable 'name' to 'value'");
	puts(  "  -V              Show version information and exit");
	puts(  "  -W              Prompt for password (should happen automatically)");
B
Bruce Momjian 已提交
121

122 123 124 125 126
    puts(  "\nFor more information, type \"\\?\" (for internal commands) or \"\\help\"");
    puts(  "(for SQL commands) from within psql, or consult the psql section in the");
    puts(  "PostgreSQL manual, which accompanies the distribution and is also available at");
    puts(  "<http://www.postgresql.org>.");
    puts(  "Report bugs to <bugs@postgresql.org>.");
127 128

#ifndef WIN32
B
Bruce Momjian 已提交
129 130
	if (pw)
		free(pw);
131 132 133 134 135 136 137 138 139 140 141 142
#endif
}



/*
 * slashUsage
 *
 * print out help for the backslash commands
 */

#ifndef TIOCGWINSZ
B
Bruce Momjian 已提交
143 144 145 146
struct winsize
{
	int			ws_row;
	int			ws_col;
147
};
B
Bruce Momjian 已提交
148

149 150 151 152 153
#endif

void
slashUsage(PsqlSettings *pset)
{
B
Bruce Momjian 已提交
154 155 156 157
	bool		usePipe = false;
	const char *pagerenv;
	FILE	   *fout;
	struct winsize screen_size;
158 159

#ifdef TIOCGWINSZ
B
Bruce Momjian 已提交
160 161 162 163 164
	if (pset->notty == 0 &&
		(ioctl(fileno(stdout), TIOCGWINSZ, &screen_size) == -1 ||
		 screen_size.ws_col == 0 ||
		 screen_size.ws_row == 0))
	{
165
#endif
B
Bruce Momjian 已提交
166 167
		screen_size.ws_row = 24;
		screen_size.ws_col = 80;
168
#ifdef TIOCGWINSZ
B
Bruce Momjian 已提交
169
	}
170 171
#endif

B
Bruce Momjian 已提交
172 173 174 175 176 177 178 179 180 181 182 183 184
	if (pset->notty == 0 &&
		(pagerenv = getenv("PAGER")) &&
		(pagerenv[0] != '\0') &&
		screen_size.ws_row <= 36 &&
		(fout = popen(pagerenv, "w")))
	{
		usePipe = true;
		pqsignal(SIGPIPE, SIG_IGN);
	}
	else
		fout = stdout;

	/* if you add/remove a line here, change the row test above */
185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217
	fprintf(fout, " \\?             help\n");
	fprintf(fout, " \\c[onnect] [dbname|- [user|?]]\n"
                  "                 connect to new database (currently '%s')\n", PQdb(pset->db));
	fprintf(fout, " \\copy ...      perform SQL COPY with data stream to the client machine");
	fprintf(fout, " \\copyright     show PostgreSQL usage and distribution terms\n");
	fprintf(fout, " \\d <table>     describe table (or view, index, sequence)\n");
	fprintf(fout, " \\d{i|s|t|v|S}  list only indices/sequences/tables/views/system tables\n");
	fprintf(fout, " \\da            list aggregates\n");
	fprintf(fout, " \\dd [object]   list comment for table, type, function, or operator\n");
	fprintf(fout, " \\df            list functions\n");
	fprintf(fout, " \\do            list operators\n");
	fprintf(fout, " \\dT            list data types\n");
	fprintf(fout, " \\e [fname]     edit the current query buffer or <fname> with external editor\n");
	fprintf(fout, " \\echo <text>   write text to stdout\n");
	fprintf(fout, " \\g [fname]     send query to backend (and results in <fname> or |pipe)\n");
	fprintf(fout, " \\h [cmd]       help on syntax of sql commands, * for all commands\n");
	fprintf(fout, " \\i <fname>     read and execute queries from filename\n");
	fprintf(fout, " \\l             list all databases\n");
	fprintf(fout, " \\lo_export, \\lo_import, \\lo_list, \\lo_unlink\n"
                  "                 large object operations\n");
	fprintf(fout, " \\o [fname]     send all query results to <fname>, or |pipe\n");
	fprintf(fout, " \\p             show the content of the current query buffer\n");
	fprintf(fout, " \\pset [opt]    set table output options\n");
	fprintf(fout, " \\q             quit psql\n");
	fprintf(fout, " \\qecho <text>  write text to query output stream (see \\o)\n");
	fprintf(fout, " \\r             reset (clear) the query buffer\n");
	fprintf(fout, " \\s [fname]     print history or save it in <fname>\n");
	fprintf(fout, " \\set <var> [value]  set/unset internal variable\n");
	fprintf(fout, " \\t             don't show table headers or footers (currently %s)\n", ON(pset->popt.topt.tuples_only));
	fprintf(fout, " \\x             toggle expanded output (currently %s)\n", ON(pset->popt.topt.expanded));
	fprintf(fout, " \\w <fname>     write current query buffer to a file\n");
	fprintf(fout, " \\z             list table access permissions\n");
	fprintf(fout, " \\! [cmd]       shell escape or command\n");
B
Bruce Momjian 已提交
218 219 220 221 222 223

	if (usePipe)
	{
		pclose(fout);
		pqsignal(SIGPIPE, SIG_DFL);
	}
224 225 226 227 228 229 230 231 232 233 234
}



/*
 * helpSQL -- help with SQL commands
 *
 */
void
helpSQL(const char *topic)
{
B
Bruce Momjian 已提交
235
	if (!topic || strlen(topic) == 0)
236
	{
B
Bruce Momjian 已提交
237 238 239
		char		left_center_right;	/* Which column we're displaying */
		int			i;			/* Index into QL_HELP[] */

240
		puts("Available help:");
B
Bruce Momjian 已提交
241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264

		left_center_right = 'L';/* Start with left column */
		i = 0;
		while (QL_HELP[i].cmd != NULL)
		{
			switch (left_center_right)
			{
				case 'L':
					printf("    %-25s", QL_HELP[i].cmd);
					left_center_right = 'C';
					break;
				case 'C':
					printf("%-25s", QL_HELP[i].cmd);
					left_center_right = 'R';
					break;
				case 'R':
					printf("%-25s\n", QL_HELP[i].cmd);
					left_center_right = 'L';
					break;
			}
			i++;
		}
		if (left_center_right != 'L')
			puts("\n");
265 266
	}

B
Bruce Momjian 已提交
267
	else
268
	{
B
Bruce Momjian 已提交
269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284
		int			i;
		bool		help_found = false;

		for (i = 0; QL_HELP[i].cmd; i++)
		{
			if (strcasecmp(QL_HELP[i].cmd, topic) == 0 ||
				strcmp(topic, "*") == 0)
			{
				help_found = true;
				printf("Command: %s\nDescription: %s\nSyntax:\n%s\n\n",
					 QL_HELP[i].cmd, QL_HELP[i].help, QL_HELP[i].syntax);
			}
		}

		if (!help_found)
			printf("No help available for '%s'.\nTry \\h with no arguments to see available help.\n", topic);
285 286 287 288 289 290 291 292 293
	}
}




void
print_copyright(void)
{
B
Bruce Momjian 已提交
294
	puts(
B
Bruce Momjian 已提交
295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313
		 "PostgreSQL Data Base Management System\n\n"
		 "Copyright(c) 1996 - 9 PostgreSQL Global Development Group\n\n"
		 "This software is based on Postgres95, formerly known as Postgres, which\n"
		 "contains the following notice:\n\n"
	  "Copyright(c) 1994 - 7 Regents of the University of California\n\n"
		 "Permission to use, copy, modify, and distribute this software and its\n"
		 "documentation for any purpose, without fee, and without a written agreement\n"
		 "is hereby granted, provided that the above copyright notice and this paragraph\n"
		 "and the following two paragraphs appear in all copies.\n\n"
		 "IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR\n"
		 "DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST\n"
		 "PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF\n"
		 "THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH\n"
		 "DAMAGE.\n\n"
		 "THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,\n"
		 "BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A\n"
		 "PARTICULAR PURPOSE.THE SOFTWARE PROVIDED HEREUNDER IS ON AN \"AS IS\" BASIS,\n"
		 "AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE,\n"
		 "SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.");
314
}