Header And Logo

PostgreSQL
| The world's most advanced open source database.

Data Structures | Defines | Enumerations | Functions | Variables

startup.c File Reference

#include "postgres_fe.h"
#include <sys/types.h>
#include <unistd.h>
#include "getopt_long.h"
#include <locale.h>
#include "command.h"
#include "common.h"
#include "describe.h"
#include "help.h"
#include "input.h"
#include "mainloop.h"
#include "settings.h"
Include dependency graph for startup.c:

Go to the source code of this file.

Data Structures

struct  adhoc_opts

Defines

#define SYSPSQLRC   "psqlrc"
#define PSQLRC   ".psqlrc"
#define PARAMS_ARRAY_SIZE   8

Enumerations

enum  _actions {
  ACT_NOTHING = 0, ACT_SINGLE_SLASH, ACT_LIST_DB, ACT_SINGLE_QUERY,
  ACT_FILE
}

Functions

static void parse_psql_options (int argc, char *argv[], struct adhoc_opts *options)
static void process_psqlrc (char *argv0)
static void process_psqlrc_file (char *filename)
static void showVersion (void)
static void EstablishVariableSpace (void)
int main (int argc, char *argv[])
static void autocommit_hook (const char *newval)
static void on_error_stop_hook (const char *newval)
static void quiet_hook (const char *newval)
static void singleline_hook (const char *newval)
static void singlestep_hook (const char *newval)
static void fetch_count_hook (const char *newval)
static void echo_hook (const char *newval)
static void echo_hidden_hook (const char *newval)
static void on_error_rollback_hook (const char *newval)
static void histcontrol_hook (const char *newval)
static void prompt1_hook (const char *newval)
static void prompt2_hook (const char *newval)
static void prompt3_hook (const char *newval)
static void verbosity_hook (const char *newval)

Variables

PsqlSettings pset

Define Documentation

#define PARAMS_ARRAY_SIZE   8
#define PSQLRC   ".psqlrc"

Definition at line 40 of file startup.c.

Referenced by process_psqlrc().

#define SYSPSQLRC   "psqlrc"

Definition at line 39 of file startup.c.

Referenced by process_psqlrc().


Enumeration Type Documentation

enum _actions
Enumerator:
ACT_NOTHING 
ACT_SINGLE_SLASH 
ACT_LIST_DB 
ACT_SINGLE_QUERY 
ACT_FILE 

Definition at line 50 of file startup.c.

{
    ACT_NOTHING = 0,
    ACT_SINGLE_SLASH,
    ACT_LIST_DB,
    ACT_SINGLE_QUERY,
    ACT_FILE
};


Function Documentation

static void autocommit_hook ( const char *  newval  )  [static]

Definition at line 686 of file startup.c.

References _psqlSettings::autocommit, and ParseVariableBool().

Referenced by EstablishVariableSpace().

static void echo_hidden_hook ( const char *  newval  )  [static]

Definition at line 735 of file startup.c.

References _psqlSettings::echo_hidden, NULL, and pg_strcasecmp().

Referenced by EstablishVariableSpace().

{
    if (newval == NULL)
        pset.echo_hidden = PSQL_ECHO_HIDDEN_OFF;
    else if (strcmp(newval, "noexec") == 0)
        pset.echo_hidden = PSQL_ECHO_HIDDEN_NOEXEC;
    else if (pg_strcasecmp(newval, "off") == 0)
        pset.echo_hidden = PSQL_ECHO_HIDDEN_OFF;
    else
        pset.echo_hidden = PSQL_ECHO_HIDDEN_ON;
}

static void echo_hook ( const char *  newval  )  [static]

Definition at line 722 of file startup.c.

References _psqlSettings::echo, and NULL.

Referenced by EstablishVariableSpace().

{
    if (newval == NULL)
        pset.echo = PSQL_ECHO_NONE;
    else if (strcmp(newval, "queries") == 0)
        pset.echo = PSQL_ECHO_QUERIES;
    else if (strcmp(newval, "all") == 0)
        pset.echo = PSQL_ECHO_ALL;
    else
        pset.echo = PSQL_ECHO_NONE;
}

static void EstablishVariableSpace ( void   )  [static]
static void fetch_count_hook ( const char *  newval  )  [static]

Definition at line 716 of file startup.c.

References _psqlSettings::fetch_count, and ParseVariableNum().

Referenced by EstablishVariableSpace().

{
    pset.fetch_count = ParseVariableNum(newval, -1, -1, false);
}

static void histcontrol_hook ( const char *  newval  )  [static]

Definition at line 761 of file startup.c.

References _psqlSettings::histcontrol, and NULL.

Referenced by EstablishVariableSpace().

{
    if (newval == NULL)
        pset.histcontrol = hctl_none;
    else if (strcmp(newval, "ignorespace") == 0)
        pset.histcontrol = hctl_ignorespace;
    else if (strcmp(newval, "ignoredups") == 0)
        pset.histcontrol = hctl_ignoredups;
    else if (strcmp(newval, "ignoreboth") == 0)
        pset.histcontrol = hctl_ignoreboth;
    else
        pset.histcontrol = hctl_none;
}

int main ( int  argc,
char *  argv[] 
)

Definition at line 86 of file startup.c.

References _, ACT_FILE, ACT_LIST_DB, ACT_NOTHING, ACT_SINGLE_QUERY, ACT_SINGLE_SLASH, adhoc_opts::action, adhoc_opts::action_string, printTableOpt::border, CONNECTION_BAD, connection_warnings(), _psqlSettings::cur_cmd_interactive, _psqlSettings::cur_cmd_source, _psqlSettings::db, adhoc_opts::dbname, DEFAULT_FIELD_SEP, printTableOpt::default_footer, DEFAULT_PROMPT1, DEFAULT_PROMPT2, DEFAULT_PROMPT3, DEFAULT_RECORD_SEP, _psqlSettings::echo, _psqlSettings::encoding, printTableOpt::env_columns, EstablishVariableSpace(), EXIT_BADCONN, EXIT_FAILURE, EXIT_SUCCESS, printTableOpt::fieldSep, printTableOpt::format, free, get_progname(), _psqlSettings::getPassword, HandleSlashCmds(), adhoc_opts::host, initializeInput(), listAllDbs(), _psqlSettings::logfile, adhoc_opts::logfilename, MainLoop(), adhoc_opts::no_psqlrc, adhoc_opts::no_readline, NoticeProcessor(), _psqlSettings::notty, NULL, printTableOpt::pager, PARAMS_ARRAY_SIZE, parse_psql_options(), pg_malloc(), pg_strdup(), PG_TEXTDOMAIN, _psqlSettings::popt, adhoc_opts::port, PQconnectdbParams(), PQconnectionNeedsPassword(), PQenv2encoding(), PQerrorMessage(), PQfinish(), PQsetNoticeProcessor(), PQstatus(), process_file(), process_psqlrc(), _psqlSettings::progname, PSQL_CMD_ERROR, PSQL_ECHO_ALL, psql_scan_create(), psql_scan_destroy(), psql_scan_setup(), _psqlSettings::queryFout, _psqlSettings::queryFoutPipe, _psqlSettings::quiet, printTableOpt::recordSep, SendQuery(), separator::separator, separator::separator_zero, set_pglocale_pgservice(), setDecimalLocale(), setQFout(), setup_cancel_handler(), SetVariable(), SetVariableBool(), showVersion(), simple_prompt(), adhoc_opts::single_txn, printTableOpt::start_table, printTableOpt::stop_table, strerror(), SyncVariables(), printQueryOpt::topt, TRI_NO, TRI_YES, usage(), adhoc_opts::username, values, and _psqlSettings::vars.

{
    struct adhoc_opts options;
    int         successResult;
    char       *password = NULL;
    char       *password_prompt = NULL;
    bool        new_pass;

    set_pglocale_pgservice(argv[0], PG_TEXTDOMAIN("psql"));

    if (argc > 1)
    {
        if (strcmp(argv[1], "--help") == 0 || strcmp(argv[1], "-?") == 0)
        {
            usage();
            exit(EXIT_SUCCESS);
        }
        if (strcmp(argv[1], "--version") == 0 || strcmp(argv[1], "-V") == 0)
        {
            showVersion();
            exit(EXIT_SUCCESS);
        }
    }

#ifdef WIN32
    setvbuf(stderr, NULL, _IONBF, 0);
#endif

    setup_cancel_handler();

    pset.progname = get_progname(argv[0]);

    pset.db = NULL;
    setDecimalLocale();
    pset.encoding = PQenv2encoding();
    pset.queryFout = stdout;
    pset.queryFoutPipe = false;
    pset.cur_cmd_source = stdin;
    pset.cur_cmd_interactive = false;

    /* We rely on unmentioned fields of pset.popt to start out 0/false/NULL */
    pset.popt.topt.format = PRINT_ALIGNED;
    pset.popt.topt.border = 1;
    pset.popt.topt.pager = 1;
    pset.popt.topt.start_table = true;
    pset.popt.topt.stop_table = true;
    pset.popt.topt.default_footer = true;
    /* We must get COLUMNS here before readline() sets it */
    pset.popt.topt.env_columns = getenv("COLUMNS") ? atoi(getenv("COLUMNS")) : 0;

    pset.notty = (!isatty(fileno(stdin)) || !isatty(fileno(stdout)));

    pset.getPassword = TRI_DEFAULT;

    EstablishVariableSpace();

    SetVariable(pset.vars, "VERSION", PG_VERSION_STR);

    /* Default values for variables */
    SetVariableBool(pset.vars, "AUTOCOMMIT");
    SetVariable(pset.vars, "VERBOSITY", "default");
    SetVariable(pset.vars, "PROMPT1", DEFAULT_PROMPT1);
    SetVariable(pset.vars, "PROMPT2", DEFAULT_PROMPT2);
    SetVariable(pset.vars, "PROMPT3", DEFAULT_PROMPT3);

    parse_psql_options(argc, argv, &options);

    /*
     * If no action was specified and we're in non-interactive mode, treat
     * it as if the user had specified "-f -".  This lets single-transaction
     * mode work in this case.
     */
    if (options.action == ACT_NOTHING && pset.notty)
    {
        options.action = ACT_FILE;
        options.action_string = NULL;
    }

    /* Bail out if -1 was specified but will be ignored. */
    if (options.single_txn && options.action != ACT_FILE)
    {
        if (options.action == ACT_NOTHING)
            fprintf(stderr,_("%s: -1 can only be used in non-interactive mode\n"), pset.progname);
        else
            fprintf(stderr,_("%s: -1 is incompatible with -c and -l\n"), pset.progname);
        exit(EXIT_FAILURE);
    }

    if (!pset.popt.topt.fieldSep.separator &&
        !pset.popt.topt.fieldSep.separator_zero)
    {
        pset.popt.topt.fieldSep.separator = pg_strdup(DEFAULT_FIELD_SEP);
        pset.popt.topt.fieldSep.separator_zero = false;
    }
    if (!pset.popt.topt.recordSep.separator &&
        !pset.popt.topt.recordSep.separator_zero)
    {
        pset.popt.topt.recordSep.separator = pg_strdup(DEFAULT_RECORD_SEP);
        pset.popt.topt.recordSep.separator_zero = false;
    }

    if (options.username == NULL)
        password_prompt = pg_strdup(_("Password: "));
    else
    {
        password_prompt = pg_malloc(strlen(_("Password for user %s: ")) - 2 +
                                    strlen(options.username) + 1);
        sprintf(password_prompt, _("Password for user %s: "),
                options.username);
    }

    if (pset.getPassword == TRI_YES)
        password = simple_prompt(password_prompt, 100, false);

    /* loop until we have a password if requested by backend */
    do
    {
#define PARAMS_ARRAY_SIZE   8
        const char **keywords = pg_malloc(PARAMS_ARRAY_SIZE * sizeof(*keywords));
        const char **values = pg_malloc(PARAMS_ARRAY_SIZE * sizeof(*values));

        keywords[0] = "host";
        values[0] = options.host;
        keywords[1] = "port";
        values[1] = options.port;
        keywords[2] = "user";
        values[2] = options.username;
        keywords[3] = "password";
        values[3] = password;
        keywords[4] = "dbname";
        values[4] = (options.action == ACT_LIST_DB &&
                     options.dbname == NULL) ?
            "postgres" : options.dbname;
        keywords[5] = "fallback_application_name";
        values[5] = pset.progname;
        keywords[6] = "client_encoding";
        values[6] = (pset.notty || getenv("PGCLIENTENCODING")) ? NULL : "auto";
        keywords[7] = NULL;
        values[7] = NULL;

        new_pass = false;
        pset.db = PQconnectdbParams(keywords, values, true);
        free(keywords);
        free(values);

        if (PQstatus(pset.db) == CONNECTION_BAD &&
            PQconnectionNeedsPassword(pset.db) &&
            password == NULL &&
            pset.getPassword != TRI_NO)
        {
            PQfinish(pset.db);
            password = simple_prompt(password_prompt, 100, false);
            new_pass = true;
        }
    } while (new_pass);

    free(password);
    free(password_prompt);

    if (PQstatus(pset.db) == CONNECTION_BAD)
    {
        fprintf(stderr, "%s: %s", pset.progname, PQerrorMessage(pset.db));
        PQfinish(pset.db);
        exit(EXIT_BADCONN);
    }

    PQsetNoticeProcessor(pset.db, NoticeProcessor, NULL);

    SyncVariables();

    if (options.action == ACT_LIST_DB)
    {
        int         success;

        if (!options.no_psqlrc)
            process_psqlrc(argv[0]);

        success = listAllDbs(NULL, false);
        PQfinish(pset.db);
        exit(success ? EXIT_SUCCESS : EXIT_FAILURE);
    }

    if (options.logfilename)
    {
        pset.logfile = fopen(options.logfilename, "a");
        if (!pset.logfile)
            fprintf(stderr, _("%s: could not open log file \"%s\": %s\n"),
                    pset.progname, options.logfilename, strerror(errno));
    }

    /*
     * Now find something to do
     */

    /*
     * process file given by -f
     */
    if (options.action == ACT_FILE)
    {
        if (!options.no_psqlrc)
            process_psqlrc(argv[0]);

        successResult = process_file(options.action_string, options.single_txn, false);
    }

    /*
     * process slash command if one was given to -c
     */
    else if (options.action == ACT_SINGLE_SLASH)
    {
        PsqlScanState scan_state;

        if (pset.echo == PSQL_ECHO_ALL)
            puts(options.action_string);

        scan_state = psql_scan_create();
        psql_scan_setup(scan_state,
                        options.action_string,
                        strlen(options.action_string));

        successResult = HandleSlashCmds(scan_state, NULL) != PSQL_CMD_ERROR
            ? EXIT_SUCCESS : EXIT_FAILURE;

        psql_scan_destroy(scan_state);
    }

    /*
     * If the query given to -c was a normal one, send it
     */
    else if (options.action == ACT_SINGLE_QUERY)
    {
        if (pset.echo == PSQL_ECHO_ALL)
            puts(options.action_string);

        successResult = SendQuery(options.action_string)
            ? EXIT_SUCCESS : EXIT_FAILURE;
    }

    /*
     * or otherwise enter interactive main loop
     */
    else
    {
        if (!options.no_psqlrc)
            process_psqlrc(argv[0]);

        connection_warnings(true);
        if (!pset.quiet)
            printf(_("Type \"help\" for help.\n\n"));
        initializeInput(options.no_readline ? 0 : 1);
        successResult = MainLoop(stdin);
    }

    /* clean up */
    if (pset.logfile)
        fclose(pset.logfile);
    PQfinish(pset.db);
    setQFout(NULL);

    return successResult;
}

static void on_error_rollback_hook ( const char *  newval  )  [static]

Definition at line 748 of file startup.c.

References NULL, _psqlSettings::on_error_rollback, and pg_strcasecmp().

Referenced by EstablishVariableSpace().

{
    if (newval == NULL)
        pset.on_error_rollback = PSQL_ERROR_ROLLBACK_OFF;
    else if (pg_strcasecmp(newval, "interactive") == 0)
        pset.on_error_rollback = PSQL_ERROR_ROLLBACK_INTERACTIVE;
    else if (pg_strcasecmp(newval, "off") == 0)
        pset.on_error_rollback = PSQL_ERROR_ROLLBACK_OFF;
    else
        pset.on_error_rollback = PSQL_ERROR_ROLLBACK_ON;
}

static void on_error_stop_hook ( const char *  newval  )  [static]

Definition at line 692 of file startup.c.

References _psqlSettings::on_error_stop, and ParseVariableBool().

Referenced by EstablishVariableSpace().

static void parse_psql_options ( int  argc,
char *  argv[],
struct adhoc_opts options 
) [static]

Definition at line 354 of file startup.c.

References _, adhoc_opts::action, adhoc_opts::action_string, adhoc_opts::dbname, DeleteVariable(), do_pset(), EXIT_FAILURE, EXIT_SUCCESS, printTableOpt::expanded, printTableOpt::fieldSep, printTableOpt::format, free, getopt_long(), _psqlSettings::getPassword, adhoc_opts::host, adhoc_opts::logfilename, adhoc_opts::no_psqlrc, adhoc_opts::no_readline, NULL, optarg, optind, pg_strdup(), _psqlSettings::popt, adhoc_opts::port, _psqlSettings::progname, _psqlSettings::quiet, printTableOpt::recordSep, separator::separator, separator::separator_zero, setQFout(), SetVariable(), SetVariableBool(), showVersion(), adhoc_opts::single_txn, printTableOpt::tableAttr, printQueryOpt::topt, printTableOpt::tuples_only, usage(), adhoc_opts::username, value, and _psqlSettings::vars.

Referenced by main().

{
    static struct option long_options[] =
    {
        {"echo-all", no_argument, NULL, 'a'},
        {"no-align", no_argument, NULL, 'A'},
        {"command", required_argument, NULL, 'c'},
        {"dbname", required_argument, NULL, 'd'},
        {"echo-queries", no_argument, NULL, 'e'},
        {"echo-hidden", no_argument, NULL, 'E'},
        {"file", required_argument, NULL, 'f'},
        {"field-separator", required_argument, NULL, 'F'},
        {"field-separator-zero", no_argument, NULL, 'z'},
        {"host", required_argument, NULL, 'h'},
        {"html", no_argument, NULL, 'H'},
        {"list", no_argument, NULL, 'l'},
        {"log-file", required_argument, NULL, 'L'},
        {"no-readline", no_argument, NULL, 'n'},
        {"single-transaction", no_argument, NULL, '1'},
        {"output", required_argument, NULL, 'o'},
        {"port", required_argument, NULL, 'p'},
        {"pset", required_argument, NULL, 'P'},
        {"quiet", no_argument, NULL, 'q'},
        {"record-separator", required_argument, NULL, 'R'},
        {"record-separator-zero", no_argument, NULL, '0'},
        {"single-step", no_argument, NULL, 's'},
        {"single-line", no_argument, NULL, 'S'},
        {"tuples-only", no_argument, NULL, 't'},
        {"table-attr", required_argument, NULL, 'T'},
        {"username", required_argument, NULL, 'U'},
        {"set", required_argument, NULL, 'v'},
        {"variable", required_argument, NULL, 'v'},
        {"version", no_argument, NULL, 'V'},
        {"no-password", no_argument, NULL, 'w'},
        {"password", no_argument, NULL, 'W'},
        {"expanded", no_argument, NULL, 'x'},
        {"no-psqlrc", no_argument, NULL, 'X'},
        {"help", no_argument, NULL, '?'},
        {NULL, 0, NULL, 0}
    };

    int         optindex;
    extern char *optarg;
    extern int  optind;
    int         c;

    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",
                            long_options, &optindex)) != -1)
    {
        switch (c)
        {
            case 'a':
                SetVariable(pset.vars, "ECHO", "all");
                break;
            case 'A':
                pset.popt.topt.format = PRINT_UNALIGNED;
                break;
            case 'c':
                options->action_string = pg_strdup(optarg);
                if (optarg[0] == '\\')
                {
                    options->action = ACT_SINGLE_SLASH;
                    options->action_string++;
                }
                else
                    options->action = ACT_SINGLE_QUERY;
                break;
            case 'd':
                options->dbname = pg_strdup(optarg);
                break;
            case 'e':
                SetVariable(pset.vars, "ECHO", "queries");
                break;
            case 'E':
                SetVariableBool(pset.vars, "ECHO_HIDDEN");
                break;
            case 'f':
                options->action = ACT_FILE;
                options->action_string = pg_strdup(optarg);
                break;
            case 'F':
                pset.popt.topt.fieldSep.separator = pg_strdup(optarg);
                pset.popt.topt.fieldSep.separator_zero = false;
                break;
            case 'h':
                options->host = pg_strdup(optarg);
                break;
            case 'H':
                pset.popt.topt.format = PRINT_HTML;
                break;
            case 'l':
                options->action = ACT_LIST_DB;
                break;
            case 'L':
                options->logfilename = pg_strdup(optarg);
                break;
            case 'n':
                options->no_readline = true;
                break;
            case 'o':
                setQFout(optarg);
                break;
            case 'p':
                options->port = pg_strdup(optarg);
                break;
            case 'P':
                {
                    char       *value;
                    char       *equal_loc;
                    bool        result;

                    value = pg_strdup(optarg);
                    equal_loc = strchr(value, '=');
                    if (!equal_loc)
                        result = do_pset(value, NULL, &pset.popt, true);
                    else
                    {
                        *equal_loc = '\0';
                        result = do_pset(value, equal_loc + 1, &pset.popt, true);
                    }

                    if (!result)
                    {
                        fprintf(stderr, _("%s: could not set printing parameter \"%s\"\n"), pset.progname, value);
                        exit(EXIT_FAILURE);
                    }

                    free(value);
                    break;
                }
            case 'q':
                SetVariableBool(pset.vars, "QUIET");
                break;
            case 'R':
                pset.popt.topt.recordSep.separator = pg_strdup(optarg);
                pset.popt.topt.recordSep.separator_zero = false;
                break;
            case 's':
                SetVariableBool(pset.vars, "SINGLESTEP");
                break;
            case 'S':
                SetVariableBool(pset.vars, "SINGLELINE");
                break;
            case 't':
                pset.popt.topt.tuples_only = true;
                break;
            case 'T':
                pset.popt.topt.tableAttr = pg_strdup(optarg);
                break;
            case 'U':
                options->username = pg_strdup(optarg);
                break;
            case 'v':
                {
                    char       *value;
                    char       *equal_loc;

                    value = pg_strdup(optarg);
                    equal_loc = strchr(value, '=');
                    if (!equal_loc)
                    {
                        if (!DeleteVariable(pset.vars, value))
                        {
                            fprintf(stderr, _("%s: could not delete variable \"%s\"\n"),
                                    pset.progname, value);
                            exit(EXIT_FAILURE);
                        }
                    }
                    else
                    {
                        *equal_loc = '\0';
                        if (!SetVariable(pset.vars, value, equal_loc + 1))
                        {
                            fprintf(stderr, _("%s: could not set variable \"%s\"\n"),
                                    pset.progname, value);
                            exit(EXIT_FAILURE);
                        }
                    }

                    free(value);
                    break;
                }
            case 'V':
                showVersion();
                exit(EXIT_SUCCESS);
            case 'w':
                pset.getPassword = TRI_NO;
                break;
            case 'W':
                pset.getPassword = TRI_YES;
                break;
            case 'x':
                pset.popt.topt.expanded = true;
                break;
            case 'X':
                options->no_psqlrc = true;
                break;
            case 'z':
                pset.popt.topt.fieldSep.separator_zero = true;
                break;
            case '0':
                pset.popt.topt.recordSep.separator_zero = true;
                break;
            case '1':
                options->single_txn = true;
                break;
            case '?':
                /* Actual help option given */
                if (strcmp(argv[optind - 1], "-?") == 0 || strcmp(argv[optind - 1], "--help") == 0)
                {
                    usage();
                    exit(EXIT_SUCCESS);
                }
                /* unknown option reported by getopt */
                else
                {
                    fprintf(stderr, _("Try \"%s --help\" for more information.\n"),
                            pset.progname);
                    exit(EXIT_FAILURE);
                }
                break;
            default:
                fprintf(stderr, _("Try \"%s --help\" for more information.\n"),
                        pset.progname);
                exit(EXIT_FAILURE);
                break;
        }
    }

    /*
     * if we still have arguments, use it as the database name and username
     */
    while (argc - optind >= 1)
    {
        if (!options->dbname)
            options->dbname = argv[optind];
        else if (!options->username)
            options->username = argv[optind];
        else if (!pset.quiet)
            fprintf(stderr, _("%s: warning: extra command-line argument \"%s\" ignored\n"),
                    pset.progname, argv[optind]);

        optind++;
    }
}

static void process_psqlrc ( char *  argv0  )  [static]

Definition at line 607 of file startup.c.

References expand_tilde(), find_my_exec(), get_etc_path(), get_home_path(), MAXPGPATH, my_exec_path, NULL, process_psqlrc_file(), PSQLRC, pstrdup(), snprintf(), and SYSPSQLRC.

Referenced by main().

{
    char        home[MAXPGPATH];
    char        rc_file[MAXPGPATH];
    char        my_exec_path[MAXPGPATH];
    char        etc_path[MAXPGPATH];
    char       *envrc = getenv("PSQLRC");

    find_my_exec(argv0, my_exec_path);
    get_etc_path(my_exec_path, etc_path);

    snprintf(rc_file, MAXPGPATH, "%s/%s", etc_path, SYSPSQLRC);
    process_psqlrc_file(rc_file);

    if (envrc != NULL && strlen(envrc) > 0)
    {
        /* might need to free() this */
        char *envrc_alloc = pstrdup(envrc);

        expand_tilde(&envrc_alloc);
        process_psqlrc_file(envrc_alloc);
    }
    else if (get_home_path(home))
    {
        snprintf(rc_file, MAXPGPATH, "%s/%s", home, PSQLRC);
        process_psqlrc_file(rc_file);
    }
}

static void process_psqlrc_file ( char *  filename  )  [static]

Definition at line 639 of file startup.c.

References free, pg_malloc(), and process_file().

Referenced by process_psqlrc().

{
    char       *psqlrc_minor,
               *psqlrc_major;

#if defined(WIN32) && (!defined(__MINGW32__))
#define R_OK 4
#endif

    psqlrc_minor = pg_malloc(strlen(filename) + 1 + strlen(PG_VERSION) + 1);
    sprintf(psqlrc_minor, "%s-%s", filename, PG_VERSION);
    psqlrc_major = pg_malloc(strlen(filename) + 1 + strlen(PG_MAJORVERSION) + 1);
    sprintf(psqlrc_major, "%s-%s", filename, PG_MAJORVERSION);

    /* check for minor version first, then major, then no version */
    if (access(psqlrc_minor, R_OK) == 0)
        (void) process_file(psqlrc_minor, false, false);
    else if (access(psqlrc_major, R_OK) == 0)
        (void) process_file(psqlrc_major, false, false);
    else if (access(filename, R_OK) == 0)
        (void) process_file(filename, false, false);

    free(psqlrc_minor);
    free(psqlrc_major);
}

static void prompt1_hook ( const char *  newval  )  [static]

Definition at line 776 of file startup.c.

References _psqlSettings::prompt1.

Referenced by EstablishVariableSpace().

{
    pset.prompt1 = newval ? newval : "";
}

static void prompt2_hook ( const char *  newval  )  [static]

Definition at line 782 of file startup.c.

References _psqlSettings::prompt2.

Referenced by EstablishVariableSpace().

{
    pset.prompt2 = newval ? newval : "";
}

static void prompt3_hook ( const char *  newval  )  [static]

Definition at line 788 of file startup.c.

References _psqlSettings::prompt3.

Referenced by EstablishVariableSpace().

{
    pset.prompt3 = newval ? newval : "";
}

static void quiet_hook ( const char *  newval  )  [static]

Definition at line 698 of file startup.c.

References ParseVariableBool(), and _psqlSettings::quiet.

Referenced by EstablishVariableSpace().

{
    pset.quiet = ParseVariableBool(newval);
}

static void showVersion ( void   )  [static]

Definition at line 672 of file startup.c.

Referenced by main(), and parse_psql_options().

{
    puts("psql (PostgreSQL) " PG_VERSION);
}

static void singleline_hook ( const char *  newval  )  [static]

Definition at line 704 of file startup.c.

References ParseVariableBool(), and _psqlSettings::singleline.

Referenced by EstablishVariableSpace().

static void singlestep_hook ( const char *  newval  )  [static]

Definition at line 710 of file startup.c.

References ParseVariableBool(), and _psqlSettings::singlestep.

Referenced by EstablishVariableSpace().

static void verbosity_hook ( const char *  newval  )  [static]

Definition at line 794 of file startup.c.

References _psqlSettings::db, NULL, PQsetErrorVerbosity(), and _psqlSettings::verbosity.

Referenced by EstablishVariableSpace().

{
    if (newval == NULL)
        pset.verbosity = PQERRORS_DEFAULT;
    else if (strcmp(newval, "default") == 0)
        pset.verbosity = PQERRORS_DEFAULT;
    else if (strcmp(newval, "terse") == 0)
        pset.verbosity = PQERRORS_TERSE;
    else if (strcmp(newval, "verbose") == 0)
        pset.verbosity = PQERRORS_VERBOSE;
    else
        pset.verbosity = PQERRORS_DEFAULT;

    if (pset.db)
        PQsetErrorVerbosity(pset.db, pset.verbosity);
}


Variable Documentation

Definition at line 36 of file startup.c.

Referenced by AcceptResult(), CheckConnection(), command_no_begin(), connection_warnings(), ConnectionUp(), describeAggregates(), describeFunctions(), describeOneTableDetails(), describeOneTSConfig(), describeOneTSParser(), describeOperators(), describeRoles(), describeTableDetails(), describeTablespaces(), describeTypes(), do_connect(), do_copy(), do_lo_export(), do_lo_import(), do_lo_list(), do_lo_unlink(), do_watch(), exec_command(), ExecQueryUsingCursor(), fail_lo_xact(), finish_lo_xact(), finishInput(), get_prompt(), handleCopyIn(), HandleSlashCmds(), initializeInput(), is_select_command(), is_superuser(), listAllDbs(), listCasts(), listCollations(), listConversions(), listDbRoleSettings(), listDefaultACLs(), listDomains(), listEventTriggers(), listExtensionContents(), listExtensions(), listForeignDataWrappers(), listForeignServers(), listForeignTables(), listLanguages(), listOneExtensionContents(), listSchemas(), listTables(), listTSConfigs(), listTSConfigsVerbose(), listTSDictionaries(), listTSParsers(), listTSParsersVerbose(), listTSTemplates(), listUserMappings(), MainLoop(), objectDescription(), parse_slash_copy(), permissionsList(), pg_send_history(), print_lo_result(), printACLColumn(), PrintNotifications(), PrintQueryResults(), PrintQueryStatus(), PrintQueryTuples(), printSSLInfo(), process_file(), ProcessResult(), psql_error(), PSQLexec(), SendQuery(), session_username(), SetCancelConn(), setQFout(), skip_white_space(), slashUsage(), standard_strings(), start_lo_xact(), StoreQueryTuple(), SyncVariables(), and UnsyncVariables().