PostgreSQL Source Code git master
option_utils.h File Reference
#include "postgres_fe.h"
#include "common/file_utils.h"
Include dependency graph for option_utils.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Typedefs

typedef void(* help_handler) (const char *progname)
 

Functions

void handle_help_version_opts (int argc, char *argv[], const char *fixed_progname, help_handler hlp)
 
bool option_parse_int (const char *optarg, const char *optname, int min_range, int max_range, int *result)
 
bool parse_sync_method (const char *optarg, DataDirSyncMethod *sync_method)
 

Typedef Documentation

◆ help_handler

typedef void(* help_handler) (const char *progname)

Definition at line 19 of file option_utils.h.

Function Documentation

◆ handle_help_version_opts()

void handle_help_version_opts ( int  argc,
char *  argv[],
const char *  fixed_progname,
help_handler  hlp 
)

Definition at line 24 of file option_utils.c.

26{
27 if (argc > 1)
28 {
29 if (strcmp(argv[1], "--help") == 0 || strcmp(argv[1], "-?") == 0)
30 {
31 hlp(get_progname(argv[0]));
32 exit(0);
33 }
34 if (strcmp(argv[1], "--version") == 0 || strcmp(argv[1], "-V") == 0)
35 {
36 printf("%s (PostgreSQL) " PG_VERSION "\n", fixed_progname);
37 exit(0);
38 }
39 }
40}
exit(1)
const char * get_progname(const char *argv0)
Definition: path.c:575
#define printf(...)
Definition: port.h:244

References exit(), get_progname(), and printf.

Referenced by main().

◆ option_parse_int()

bool option_parse_int ( const char *  optarg,
const char *  optname,
int  min_range,
int  max_range,
int *  result 
)

Definition at line 50 of file option_utils.c.

53{
54 char *endptr;
55 int val;
56
57 errno = 0;
58 val = strtoint(optarg, &endptr, 10);
59
60 /*
61 * Skip any trailing whitespace; if anything but whitespace remains before
62 * the terminating character, fail.
63 */
64 while (*endptr != '\0' && isspace((unsigned char) *endptr))
65 endptr++;
66
67 if (*endptr != '\0')
68 {
69 pg_log_error("invalid value \"%s\" for option %s",
70 optarg, optname);
71 return false;
72 }
73
74 if (errno == ERANGE || val < min_range || val > max_range)
75 {
76 pg_log_error("%s must be in range %d..%d",
77 optname, min_range, max_range);
78 return false;
79 }
80
81 if (result)
82 *result = val;
83 return true;
84}
long val
Definition: informix.c:689
#define pg_log_error(...)
Definition: logging.h:106
PGDLLIMPORT char * optarg
Definition: getopt.c:53
int strtoint(const char *pg_restrict str, char **pg_restrict endptr, int base)
Definition: string.c:50

References optarg, pg_log_error, strtoint(), and val.

Referenced by main().

◆ parse_sync_method()

bool parse_sync_method ( const char *  optarg,
DataDirSyncMethod sync_method 
)

Definition at line 90 of file option_utils.c.

91{
92 if (strcmp(optarg, "fsync") == 0)
94 else if (strcmp(optarg, "syncfs") == 0)
95 {
96#ifdef HAVE_SYNCFS
98#else
99 pg_log_error("this build does not support sync method \"%s\"",
100 "syncfs");
101 return false;
102#endif
103 }
104 else
105 {
106 pg_log_error("unrecognized sync method: %s", optarg);
107 return false;
108 }
109
110 return true;
111}
@ DATA_DIR_SYNC_METHOD_SYNCFS
Definition: file_utils.h:30
@ DATA_DIR_SYNC_METHOD_FSYNC
Definition: file_utils.h:29
static DataDirSyncMethod sync_method
Definition: initdb.c:170

References DATA_DIR_SYNC_METHOD_FSYNC, DATA_DIR_SYNC_METHOD_SYNCFS, optarg, pg_log_error, and sync_method.

Referenced by main(), and parseCommandLine().