89#include "parser_local_proto.h"
100#define MAX_MATCHES 50
107static void set_flag(
int);
108static int contains(
const char *,
int);
109static int valid_option_name(
const char *);
110static int is_option(
const char *);
111static int match_option_1(
const char *,
const char *);
112static int match_option(
const char *,
const char *);
113static void set_option(
const char *);
114static void check_opts(
void);
115static void check_an_opt(
const char *,
int,
const char *,
const char **,
117static int check_int(
const char *,
const char **);
118static int check_double(
const char *,
const char **);
119static int check_string(
const char *,
const char **,
int *);
120static void check_required(
void);
121static void split_opts(
void);
122static void check_multiple_opts(
void);
123static int check_overwrite(
void);
124static void define_keywords(
void);
125static int module_gui_wx(
void);
126static void append_error(
const char *);
127static const char *get_renamed_option(
const char *);
141 st->no_interactive = 1;
165 st->current_flag->next_flag =
flag;
179 st->current_item->next_item = item;
182 item = &
st->first_item;
189 st->current_item = item;
219 st->current_option->next_opt =
opt;
222 opt = &
st->first_option;
230 st->current_option =
opt;
235 st->current_item->next_item = item;
238 item = &
st->first_item;
244 st->current_item = item;
260 module = &st->module_info;
348 if (!
st->module_info.label && !
st->module_info.description)
349 G_warning(
_(
"Bug in UI description. Missing module description"));
353 opt = &
st->first_option;
354 while (
st->n_opts &&
opt) {
356 st->has_required = 1;
359 G_warning(
_(
"Bug in UI description. Missing option key"));
360 if (
opt->key && !valid_option_name(
opt->key))
361 G_warning(
_(
"Bug in UI description. Option key <%s> is not valid"),
363 if (!
opt->label && !
opt->description)
365 _(
"Bug in UI description. Description for option <%s> missing"),
366 opt->key ?
opt->key :
"?");
393 if (
opt->descriptions) {
410 while (
opt->opts[
j]) {
418 G_warning(
_(
"Bug in UI description. Option '%s' in "
419 "<%s> does not exist"),
433 if (
opt->multiple &&
opt->answers &&
opt->answers[0]) {
436 for (i = 1;
opt->answers[i]; i++) {
453 if (module_gui_wx() == 0)
461 else if (
argc >= 2) {
479 if (
strcmp(
argv[1],
"--interface-description") == 0) {
486 if (
strcmp(
argv[1],
"--html-description") == 0) {
493 if (
strcmp(
argv[1],
"--rst-description") == 0) {
500 if (
strcmp(
argv[1],
"--md-description") == 0) {
507 if (
strcmp(
argv[1],
"--wps-process-description") == 0) {
524 if (
strcmp(ptr,
"help") == 0 ||
strcmp(ptr,
"--h") == 0 ||
525 strcmp(ptr,
"-help") == 0 ||
strcmp(ptr,
"--help") == 0) {
531 if (
strcmp(ptr,
"--json") == 0) {
537 if (
strcmp(ptr,
"--o") == 0 ||
strcmp(ptr,
"--overwrite") == 0) {
542 else if (
strcmp(ptr,
"--v") == 0 ||
strcmp(ptr,
"--verbose") == 0) {
547 snprintf(buff,
sizeof(buff),
"GRASS_VERBOSE=%d",
550 if (
st->quiet == 1) {
551 G_warning(
_(
"Use either --quiet or --verbose flag, not "
552 "both. Assuming --verbose."));
558 else if (
strcmp(ptr,
"--q") == 0 ||
strcmp(ptr,
"--quiet") == 0) {
563 snprintf(buff,
sizeof(buff),
"GRASS_VERBOSE=%d",
566 if (
st->quiet == -1) {
567 G_warning(
_(
"Use either --quiet or --verbose flag, not "
568 "both. Assuming --quiet."));
574 else if (
strcmp(ptr,
"--qq") == 0) {
579 snprintf(buff,
sizeof(buff),
"GRASS_VERBOSE=%d",
583 if (
st->quiet == -1) {
584 G_warning(
_(
"Use either --qq or --verbose flag, not both. "
591 else if (
strcmp(ptr,
"--ui") == 0) {
596 else if (*ptr ==
'-') {
601 else if (is_option(ptr)) {
609 st->first_option.count++;
626 if (module_gui_wx() != 0)
627 G_fatal_error(
_(
"Your installation doesn't include GUI, exiting."));
632 check_multiple_opts();
639 if (!
st->suppress_required)
644 if (
st->n_errors > 0) {
649 for (i = 0; i <
st->n_errors; i++) {
662 if (!
st->suppress_overwrite) {
663 if (check_overwrite())
691 G_debug(3,
"G_recreate_command()");
695 buff =
G_calloc(1024,
sizeof(
char));
703 nalloced += (1024 > len) ? 1024 : len + 1;
713 nalloced += (1024 > len) ? 1024 : len + 1;
716 strcpy(cur,
" --overwrite");
731 nalloced += (1024 > len) ? 1024 : len + 1;
742 if (
flag->answer == 1) {
762 opt = &
st->first_option;
763 while (
st->n_opts &&
opt) {
764 if (
opt->answer &&
opt->answer[0] ==
'\0') {
783 else if (
opt->answer &&
opt->answers &&
opt->answers[0]) {
804 for (n = 1;
opt->answers[n]; n++) {
805 if (!
opt->answers[n])
870 if (
st->n_keys >=
st->n_keys_alloc) {
871 st->n_keys_alloc += 10;
872 st->module_info.keywords =
G_realloc(
st->module_info.keywords,
873 st->n_keys_alloc *
sizeof(
char *));
888 st->module_info.keywords = (
const char **)
tokens;
899 if (
st->module_info.overwrite)
905 opt = &
st->first_option;
907 if (
opt->gisprompt) {
909 if (
strcmp(age,
"new") == 0)
934 for (i = 0; i <
st->n_keys; i++) {
936 fprintf(fd,
"%s",
st->module_info.keywords[i]);
939 format(fd,
st->module_info.keywords[i]);
961 return st->module_info.overwrite;
964void define_keywords(
void)
967 st->n_keys_alloc = 0;
980int module_gui_wx(
void)
1020 if (
flag->key == f) {
1022 if (
flag->suppress_required)
1023 st->suppress_required = 1;
1024 if (
flag->suppress_overwrite)
1025 st->suppress_overwrite = 1;
1043 G_warning(
_(
"Please update the usage of <%s>: "
1044 "flag <%c> has been renamed to <%s>"),
1053 _(
"Please update the usage of <%s>: "
1054 "flag <%c> has been renamed to <%s>"),
1063 G_warning(
_(
"Please update the usage of <%s>: "
1064 "flag <%c> has been renamed to <%s>"),
1067 if (
flag->suppress_required)
1068 st->suppress_required = 1;
1069 if (
flag->suppress_overwrite)
1070 st->suppress_overwrite = 1;
1082 _(
"Please update the usage of <%s>: "
1083 "flag <%c> has been renamed to option <%s>"),
1100int contains(
const char *s,
int c)
1110int valid_option_name(
const char *
string)
1113 int n =
strspn(
string,
"abcdefghijklmnopqrstuvwxyz0123456789_");
1121 if (
string[
m - 1] ==
'_')
1127int is_option(
const char *
string)
1129 int n =
strspn(
string,
"abcdefghijklmnopqrstuvwxyz0123456789_");
1131 return n > 0 &&
string[n] ==
'=' &&
string[0] !=
'_' &&
1132 string[n - 1] !=
'_';
1135int match_option_1(
const char *
string,
const char *
option)
1139 if (*
string ==
'\0')
1145 if (*
string == *
option && match_option_1(
string + 1,
option + 1))
1148 if (*
option ==
'_' && match_option_1(
string,
option + 1))
1156 return match_option_1(
string + 1, next + 1);
1158 return match_option_1(
string, next + 1);
1161int match_option(
const char *
string,
const char *
option)
1163 return (*
string == *
option) && match_option_1(
string + 1,
option + 1);
1166void set_option(
const char *
string)
1178 for (ptr =
the_key; *
string !=
'='; ptr++,
string++)
1213 for (i = 1; i <
found; i++) {
1232 for (i = 0; i <
found; i++) {
1253 _(
"Please update the usage of <%s>: "
1254 "option <%s> has been renamed to flag <%s>"),
1258 _(
"Please update the usage of <%s>: "
1259 "option <%s> has been renamed to flag <%c>"),
1269 G_warning(
_(
"Please update the usage of <%s>: "
1270 "option <%s> has been renamed to <%s>"),
1293 if (!
opt->multiple) {
1294 G_asprintf(&
err,
_(
"Option <%s> does not accept multiple answers"),
1307void check_opts(
void)
1315 opt = &
st->first_option;
1320 if (
opt->multiple == 0)
1321 check_an_opt(
opt->key,
opt->type,
opt->options,
opt->opts,
1325 check_an_opt(
opt->key,
opt->type,
opt->options,
opt->opts,
1333 opt->checker(
opt->answer);
1367 _(
"Illegal range syntax for parameter <%s>\n"
1368 "\tPresented as: %s"),
1374 _(
"Value <%s> out of range for parameter <%s>\n"
1375 "\tLegal range: %s"),
1390 _(
"Value <%s> ambiguous for parameter <%s>\n"
1391 "\tValid options: %s"),
1402int check_int(
const char *
ans,
const char **
opts)
1419 for (i = 0;
opts[i]; i++) {
1423 if (contains(
opt,
'-')) {
1425 if (d >=
lo && d <=
hi)
1452int check_double(
const char *
ans,
const char **
opts)
1470 for (i = 0;
opts[i]; i++) {
1474 if (contains(
opt,
'-')) {
1476 if (d >=
lo && d <=
hi)
1503int check_string(
const char *
ans,
const char **
opts,
int *result)
1513 for (i = 0;
opts[i]; i++) {
1528 for (i = 1; i <
found; i++) {
1548 if (
found > 0 &&
getenv(
"GRASS_FULL_OPTION_NAMES") &&
1562void check_required(
void)
1572 opt = &
st->first_option;
1574 if (
opt->required && !
opt->answer) {
1576 _(
"Required parameter <%s> not set:\n"
1585void split_opts(
void)
1597 opt = &
st->first_option;
1602 opt->answers =
G_malloc(allocated *
sizeof(
char *));
1642void check_multiple_opts(
void)
1654 opt = &
st->first_option;
1660 for (ptr =
opt->key_desc; *ptr !=
'\0'; ptr++)
1664 for (n = 0;
opt->answers[n] !=
NULL; n++)
1669 _(
"Option <%s> must be provided in multiples of %d\n"
1670 "\tYou provided %d item(s): %s"),
1680int check_overwrite(
void)
1690 st->module_info.overwrite = 0;
1707 if (
st->overwrite ||
over) {
1708 st->module_info.overwrite = 1;
1710 putenv(
"GRASS_OVERWRITE=1");
1715 opt = &
st->first_option;
1717 if (
opt->answer &&
opt->gisprompt) {
1720 if (
strcmp(age,
"new") == 0) {
1724 for (i = 0;
opt->answers[i]; i++) {
1739 if (!
st->overwrite && !
over) {
1744 _(
"option <%s>: <%s> exists. To "
1745 "overwrite, use the --overwrite "
1747 opt->key,
opt->answers[i]);
1754 _(
"option <%s>: <%s> exists. To "
1755 "overwrite, use the --overwrite "
1757 opt->key,
opt->answers[i]);
1803void append_error(
const char *
msg)
1805 st->error =
G_realloc(
st->error,
sizeof(
char *) * (
st->n_errors + 1));
1809const char *get_renamed_option(
const char *
key)
1814 if (!
st->renamed_options) {
1865 strcmp(
option->gisprompt,
"old,separator,separator") != 0)
1886 G_debug(3,
"G_option_to_separator(): key = %s -> sep = '%s'",
option->key,
1932 else if (
option->multiple)
1935 else if (
strcmp(
option->gisprompt,
"old,file,file") == 0) {
1942 else if (
strcmp(
option->gisprompt,
"new,file,file") == 0) {
const char * G_program_name(void)
Return module name.
const char * G_getenv_nofatal(const char *)
Get environment variable.
void G_zero(void *, int)
Zero out a buffer, buf, of length i.
void G_free(void *)
Free allocated memory.
const char * G_original_program_name(void)
Return original path of the executed program.
void void void void G_fatal_error(const char *,...) __attribute__((format(printf
void G_warning(const char *,...) __attribute__((format(printf
int G_verbose_max(void)
Get max verbosity level.
const char * G_gisbase(void)
Get full path name of the top level module directory.
const char * G_find_file(const char *, char *, const char *)
Searches for a file from the mapset search list or in a specified mapset.
char ** G_tokenize(const char *, const char *)
Tokenize string.
struct Key_Value * G_read_key_value_file(const char *)
Read key/values pairs from file.
int G_verbose(void)
Get current verbosity level.
int G_verbose_min(void)
Get min verbosity level.
void G_free_tokens(char **)
Free memory allocated to tokens.
int G_asprintf(char **, const char *,...) __attribute__((format(printf
int G_number_of_tokens(char **)
Return number of tokens.
const char * G_find_key_value(const char *, const struct Key_Value *)
Find given key (case sensitive)
int G_is_dirsep(char)
Checks if a specified character is a valid directory separator character on the host system.
int int G_strcasecmp(const char *, const char *)
String compare ignoring case (upper or lower)
char * G_chop(char *)
Chop leading and trailing white spaces.
char * G_store(const char *)
Copy string to allocated memory.
void G_usage(void)
Command line help/usage message.
int G_info_format(void)
Get current message format.
char * G_basename(char *, const char *)
Truncates filename to the base part (before the last '.') if it matches the extension,...
int G_debug(int, const char *,...) __attribute__((format(printf
int G_verbose_std(void)
Get standard verbosity level.
void int G_suppress_warnings(int)
Suppress printing a warning message to stderr.
const char * G_mapset(void)
Get current mapset name.
int G_spawn(const char *command,...)
Spawn new process based on command.
#define G_INFO_FORMAT_GUI
struct GModule * G_define_module(void)
Initializes a new module.
void G__print_keywords(FILE *fd, void(*format)(FILE *, const char *), int newline)
Print list of keywords (internal use only)
struct Flag * G_define_flag(void)
Initializes a Flag struct.
int G_parser(int argc, char **argv)
Parse command line.
void G_set_keywords(const char *keywords)
Set keywords from the string.
FILE * G_open_option_file(const struct Option *option)
Get an input/output file pointer from the option. If the file name is omitted or '-',...
int G__uses_new_gisprompt(void)
void G_add_keyword(const char *keyword)
Add keyword to the list.
int G_get_overwrite(void)
Get overwrite value.
char * G_option_to_separator(const struct Option *option)
Get separator string from the option.
char * recreate_command(int original_path)
Creates command to run non-interactive.
void G_close_option_file(FILE *fp)
Close an input/output file returned by G_open_option_file(). If the file pointer is stdin,...
char * G_recreate_command(void)
Creates command to run non-interactive.
struct Option * G_define_option(void)
Initializes an Option struct.
void G_disable_interactive(void)
Disables the ability of the parser to operate interactively.
char * G_recreate_command_original_path(void)
Creates command to run non-interactive.
void G__split_gisprompt(const char *gisprompt, char *age, char *element, char *desc)
void G__check_option_rules(void)
Check for option rules (internal use only)
int G__has_required_rule(void)
Checks if there is any rule RULE_REQUIRED (internal use only).
void G__usage_html(void)
Print module usage description in HTML format.
void G__usage_xml(void)
Print module usage description in XML format.
char * G__json(void)
This function generates actinia JSON process chain building blocks from the command line arguments th...
void G__usage_markdown(void)
Print module usage description in Markdown format.
void G__usage_rest(void)
Print module usage description in reStructuredText format.
void G__script(void)
Generate Python script-like output.
void G__wps_print_process_description(void)
Print the WPS 1.0.0 process description XML document to stdout.
Structure that stores flag info.
Structure that stores module info.
Structure that stores option information.
SYMBOL * err(FILE *fp, SYMBOL *s, char *msg)