diff options
author | Eugene Grigorjev <git-no-reply@zabbix.com> | 2006-07-12 13:14:46 +0400 |
---|---|---|
committer | Eugene Grigorjev <git-no-reply@zabbix.com> | 2006-07-12 13:14:46 +0400 |
commit | 3c44ccda3b18ac5ed983c2bf163439bb70f5c1e5 (patch) | |
tree | d62c05933f09bebc50d4c9c9dfa61f657ab03e54 /include/zbxgetopt.h | |
parent | 525dcd4757f8356cfad70e233cbc6e0dd29bc34e (diff) |
zabbix-1.2_dev integration
Diffstat (limited to 'include/zbxgetopt.h')
-rwxr-xr-x | include/zbxgetopt.h | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/include/zbxgetopt.h b/include/zbxgetopt.h new file mode 100755 index 00000000000..68d9e691c44 --- /dev/null +++ b/include/zbxgetopt.h @@ -0,0 +1,102 @@ +/* Declarations for getopt. + Copyright (C) 1989, 1990, 1991, 1992, 1993 Free Software Foundation, Inc. + + This program is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published by the + Free Software Foundation; either version 2, or (at your option) any + later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ + +#ifndef ZBX_GETOPT_H +#define ZBX_GETOPT_H 1 + +#ifdef __cplusplus +extern "C" { +#endif + +/* For communication from `getopt' to the caller. + When `getopt' finds an option that takes an argument, + the argument value is returned here. + Also, when `ordering' is RETURN_IN_ORDER, + each non-option ARGV-element is returned here. */ + +extern char *zbx_optarg; + +/* Index in ARGV of the next element to be scanned. + This is used for communication to and from the caller + and for communication between successive calls to `getopt'. + + On entry to `getopt', zero means this is the first call; initialize. + + When `getopt' returns EOF, this is the index of the first of the + non-option elements that the caller should itself scan. + + Otherwise, `optind' communicates from one call to the next + how much of ARGV has been scanned so far. */ + +extern int zbx_optind; + +/* Callers store zero here to inhibit the error message `getopt' prints + for unrecognized options. */ + +extern int zbx_opterr; + +/* Set to an option character which was unrecognized. */ + +extern int zbx_optopt; + +/* Describe the long-named options requested by the application. + The LONG_OPTIONS argument to getopt_long or getopt_long_only is a vector + of `struct option' terminated by an element containing a name which is + zero. + + The field `has_arg' is: + no_argument (or 0) if the option does not take an argument, + required_argument (or 1) if the option requires an argument, + optional_argument (or 2) if the option takes an optional argument. + + If the field `flag' is not NULL, it points to a variable that is set + to the value given in the field `val' when the option is found, but + left unchanged if the option is not found. + + To have a long-named option do something other than set an `int' to + a compiled-in constant, such as set a value from `optarg', set the + option's `flag' field to zero and its `val' field to a nonzero + value (the equivalent single-letter option character, if there is + one). For long options that have a zero `flag' field, `getopt' + returns the contents of the `val' field. */ + +struct zbx_option +{ + const char *name; + /* has_arg can't be an enum because some compilers complain about + type mismatches in all the code that assumes it is an int. */ + int has_arg; + int *flag; + int val; +}; + +/* Names for the values of the `has_arg' field of `struct option'. */ + +#define zbx_no_argument 0 +#define zbx_required_argument 1 +#define zbx_optional_argument 2 +#define zbx_exact_argument 0x10 /* no abbrev. */ + +int zbx_getopt(int argc, char **argv, const char *optstring); +int zbx_getopt_long(int argc, char **argv, const char *options, + const struct zbx_option *long_options, int *opt_index); + +#ifdef __cplusplus +} +#endif + +#endif /* ZBX_GETOPT_H */ |