blob: 1c611d62ae9b1c0c1e623231481d27c3448fc3b3 [file] [log] [blame]
#ifndef MARISA_CMDOPT_H_
#define MARISA_CMDOPT_H_
#ifdef __cplusplus
extern "C" {
#endif
typedef struct cmdopt_option_ {
// `name' specifies the name of this option.
// An array of options must be terminated with an option whose name == NULL.
const char *name;
// `has_name' specifies whether an option takes an argument or not.
// 0 specifies that this option does not have any argument.
// 1 specifies that this option has an argument.
// 2 specifies that this option may have an argument.
int has_arg;
// `flag' specifies an integer variable which is overwritten by cmdopt_next()
// with its return value.
int *flag;
// `val' specifies a return value of cmdopt_next(). This value is returned
// when cmdopt_next() finds this option.
int val;
} cmdopt_option;
typedef struct cmdopt_t_ {
// Command line arguments.
int argc;
char **argv;
// Option settings.
const cmdopt_option *longopts;
const char *optstring;
int optind; // Index of the next argument.
char *nextchar; // Next character.
char *optarg; // Argument of the last option.
int optopt; // Label of the last option.
char *optlong; // Long option.
int opterr; // Warning level (0: nothing, 1: warning, 2: all).
int longindex; // Index of the last long option.
int optnum; // Number of options.
} cmdopt_t;
// cmdopt_init() initializes a cmdopt_t for successive cmdopt_next()s.
void cmdopt_init(cmdopt_t *h, int argc, char **argv,
const char *optstring, const cmdopt_option *longopts);
// cmdopt_get() analyzes command line arguments and gets the next option.
int cmdopt_get(cmdopt_t *h);
#ifdef __cplusplus
} // extern "C"
#endif
#endif // MARISA_CMDOPT_H_