Annotation of coherent/g/usr/lib/uucp/tay104/getopt.h, revision 1.1.1.1

1.1       root        1: /* Declarations for getopt.
                      2:    Copyright (C) 1989, 1990, 1991, 1992 Free Software Foundation, Inc.
                      3: 
                      4:    This program is free software; you can redistribute it and/or modify it
                      5:    under the terms of the GNU General Public License as published by the
                      6:    Free Software Foundation; either version 2, or (at your option) any
                      7:    later version.
                      8:    
                      9:    This program is distributed in the hope that it will be useful,
                     10:    but WITHOUT ANY WARRANTY; without even the implied warranty of
                     11:    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     12:    GNU General Public License for more details.
                     13:    
                     14:    You should have received a copy of the GNU General Public License
                     15:    along with this program; if not, write to the Free Software
                     16:    Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
                     17: 
                     18:    This file was modified slightly by Ian Lance Taylor, November 1992,
                     19:    for Taylor UUCP.  */
                     20: 
                     21: #ifndef _GETOPT_H
                     22: #define _GETOPT_H 1
                     23: 
                     24: #ifdef __cplusplus
                     25: extern "C" {
                     26: #endif
                     27: 
                     28: /* Ian Lance Taylor <[email protected]> added the following defines for
                     29:    Taylor UUCP.  This avoids reported conflicts with system getopt
                     30:    definitions.  */
                     31: #define getopt gnu_getopt
                     32: #define optarg gnu_optarg
                     33: #define optind gnu_optind
                     34: #define opterr gnu_opterr
                     35: 
                     36: /* For communication from `getopt' to the caller.
                     37:    When `getopt' finds an option that takes an argument,
                     38:    the argument value is returned here.
                     39:    Also, when `ordering' is RETURN_IN_ORDER,
                     40:    each non-option ARGV-element is returned here.  */
                     41: 
                     42: extern char *optarg;
                     43: 
                     44: /* Index in ARGV of the next element to be scanned.
                     45:    This is used for communication to and from the caller
                     46:    and for communication between successive calls to `getopt'.
                     47: 
                     48:    On entry to `getopt', zero means this is the first call; initialize.
                     49: 
                     50:    When `getopt' returns EOF, this is the index of the first of the
                     51:    non-option elements that the caller should itself scan.
                     52: 
                     53:    Otherwise, `optind' communicates from one call to the next
                     54:    how much of ARGV has been scanned so far.  */
                     55: 
                     56: extern int optind;
                     57: 
                     58: /* Callers store zero here to inhibit the error message `getopt' prints
                     59:    for unrecognized options.  */
                     60: 
                     61: extern int opterr;
                     62: 
                     63: /* Describe the long-named options requested by the application.
                     64:    The LONG_OPTIONS argument to getopt_long or getopt_long_only is a vector
                     65:    of `struct option' terminated by an element containing a name which is
                     66:    zero.
                     67: 
                     68:    The field `has_arg' is:
                     69:    no_argument         (or 0) if the option does not take an argument,
                     70:    required_argument   (or 1) if the option requires an argument,
                     71:    optional_argument   (or 2) if the option takes an optional argument.
                     72: 
                     73:    If the field `flag' is not NULL, it points to a variable that is set
                     74:    to the value given in the field `val' when the option is found, but
                     75:    left unchanged if the option is not found.
                     76: 
                     77:    To have a long-named option do something other than set an `int' to
                     78:    a compiled-in constant, such as set a value from `optarg', set the
                     79:    option's `flag' field to zero and its `val' field to a nonzero
                     80:    value (the equivalent single-letter option character, if there is
                     81:    one).  For long options that have a zero `flag' field, `getopt'
                     82:    returns the contents of the `val' field.  */
                     83: 
                     84: struct option
                     85: {
                     86:   const char *name;
                     87:   /* has_arg can't be an enum because some compilers complain about
                     88:      type mismatches in all the code that assumes it is an int.  */
                     89:   int has_arg;
                     90:   int *flag;
                     91:   int val;
                     92: };
                     93: 
                     94: /* Names for the values of the `has_arg' field of `struct option'.  */
                     95: 
                     96: enum _argtype
                     97: {
                     98:   no_argument,
                     99:   required_argument,
                    100:   optional_argument
                    101: };
                    102: 
                    103: extern int getopt P((int argc, char *const *argv, const char *shortopts));
                    104: extern int getopt_long P((int argc, char *const *argv, const char *shortopts,
                    105:                          const struct option *longopts, int *longind));
                    106: extern int getopt_long_only P((int argc, char *const *argv,
                    107:                               const char *shortopts,
                    108:                               const struct option *longopts, int *longind));
                    109: 
                    110: /* Internal only.  Users should not call this directly.  */
                    111: extern int _getopt_internal P((int argc, char *const *argv,
                    112:                               const char *shortopts,
                    113:                               const struct option *longopts, int *longind,
                    114:                               int long_only));
                    115: 
                    116: #ifdef __cplusplus
                    117: }
                    118: #endif
                    119: 
                    120: #endif /* _GETOPT_H */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.