1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
/** BEGIN COPYRIGHT BLOCK
* Copyright (C) 2001 Sun Microsystems, Inc. Used by permission.
* Copyright (C) 2005 Red Hat, Inc.
* All rights reserved.
*
* License: GPL (version 3 or any later version).
* See LICENSE for details.
* END COPYRIGHT BLOCK **/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
/*
* getopt_ext.h - long option names
*
*
*
*/
#ifndef _GETOPT_EXT_H
#define _GETOPT_EXT_H
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#ifdef LINUX
#include <getopt.h>
#endif
#ifdef __cplusplus
extern "C" {
#endif
/*
* getopt_ext() is a rudimentary extension to getopt() to facilitate
* handling of long (wordier) option names.
*
* A long option is indicated by placing a "--" in front of the option
* name.
*
* Like getopt(), getopt_ext() also returns a single letter (actually an int)
* when an option is recognized. Therefore, the loop for processing long
* options and single letter options can be combined (see example in
* slapd/main.c)
*
* getopt_ext() first processes all the long options it can find. Currently,
* it does a "strcmp" to check for the validity of the option name (i.e.,
* the option name has to match exactly).
*
* Once all the long options are handled, getopt_ext() uses getopt() to
* process the remaining options.
*
* getopt_ext() rearranges "argv" when it finds long options that it
* recognizes. The recognized options (and their parameters) are pushed
* to the end.
*
* Single letter options are specified similar to getopt()
* Long options are specified using a list of "struct opt_ext". Each long
* option consists of string that identifies the option, a type that specifies
* if the option requires an argument and the single letter returned by
* getopt_ext() when the option is encountered. For example,
* {"verbose",ArgNone,'v'} specifies a long option (--verbose) that requires
* no arguments and for which, getopt_ext() returns a 'v' as the return value.
* {"instancedir",ArgRequired,'D'} specifies a long option (--instancedir dir)
* that requires an argument.
*
*
*/
extern char *optarg_ext;
extern int optind_ext;
extern int optopt_ext;
extern int opterr_ext;
extern int optind_last;
extern int optind, opterr, optopt;
extern char *optarg;
typedef enum {
ArgNone,
ArgRequired,
ArgOptional
} GetOptExtArgType;
struct opt_ext
{
const char *o_string;
const GetOptExtArgType o_type;
const char o_return;
};
int getopt_ext(int argc,
char **argv,
const char *optstring,
const struct opt_ext *longOpts,
int *longOptIndex);
#ifdef __cplusplus
}
#endif
#endif
|