File: cio_commandline.h

package info (click to toggle)
eprover 2.6%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 21,288 kB
  • sloc: ansic: 331,111; csh: 12,026; python: 10,178; awk: 5,825; makefile: 461; sh: 389
file content (109 lines) | stat: -rw-r--r-- 3,576 bytes parent folder | download | duplicates (2)
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
107
108
109
/*-----------------------------------------------------------------------

File  : cio_commandline.h

Author: Stephan Schulz

Contents

  Definitions for handling options and recognising non-option
  arguments.

  "Why don't you use getopt()?"

  - Implementations of getopt() seem to differ significantly between
    UNIX implementations. Finding out what the differences are and
    coding around them seems to be more work than writing this version
    from scratch.
  - This implementation comes with more support for the handling of
    numerical arguments for options.
  - Finally, this implementation allows (well, forces) the programmer
    to document an option _immediately_, and automates the process of
    presenting this information to the user.

  Copyright 1998, 1999 by the author.
  This code is released under the GNU General Public Licence and
  the GNU Lesser General Public License.
  See the file COPYING in the main E directory for details..
  Run "eprover -h" for contact information.

Changes

<1> Sun Sep  7 00:38:12 MET DST 1997
    New

-----------------------------------------------------------------------*/

#ifndef CIO_COMMANDLINE

#define CIO_COMMANDLINE

#include <clb_dstrings.h>


/*---------------------------------------------------------------------*/
/*                    Data type declarations                           */
/*---------------------------------------------------------------------*/

/* Supported option types: */

typedef enum
{
   NoArg,
   OptArg,
   ReqArg
}OptArgType;

typedef struct optcell
{
   int         option_code;
   char        shortopt;    /* Single Character options */
   char*       longopt;     /* Double dash, GNU-Style */
   OptArgType  type;        /* What about Arguments? */
   char*       arg_default; /* Default for optional argument (long
                style only */
   char*       desc;        /* Put the documentation in immediately! */
}OptCell, *Opt_p;


typedef struct clstatecell
{
   int     sc_opt_c;  /* Which character of the current element of
          argv has to be read next? */
   int     argi;      /* Which element of argv[] ? */
   int     argsize;   /* How large is the argv array really? */
   int     argc;      /* How many elements in argv[]? */
   char**  argv;      /* Vector of arguments. Processed options and
          option args will be removed */
}CLStateCell, *CLState_p;

/*---------------------------------------------------------------------*/
/*                Exported Functions and Variables                     */
/*---------------------------------------------------------------------*/

#define CLStateCellAlloc() (CLStateCell*)SizeMalloc(sizeof(CLStateCell))
#define CLStateCellFree(junk)        SizeFree(junk, sizeof(CLStateCell))


#define FORMAT_WIDTH 78

CLState_p CLStateAlloc(int argc, char* argv[]);
void      CLStateFree(CLState_p junk);

Opt_p  CLStateGetOpt(CLState_p state, char** arg, OptCell options[]);
int    CLStateInsertArg(CLState_p state, char* arg);

double CLStateGetFloatArg(Opt_p option, char* arg);
long   CLStateGetIntArg(Opt_p option, char* arg);
long   CLStateGetIntArgCheckRange(Opt_p option, char* arg, long lower, long upper);
bool   CLStateGetBoolArg(Opt_p option, char* arg);

void PrintOption(FILE* out, Opt_p option);
void PrintOptions(FILE* out, OptCell option[], char* header);


#endif

/*---------------------------------------------------------------------*/
/*                        End of File                                  */
/*---------------------------------------------------------------------*/