/* * parseargs.h * * Command line argument parser. * * Copyright 1996-2003 Glyph & Cog, LLC * Copyright 2020 Adam Sampson */ #ifndef PARSEARGS_H #define PARSEARGS_H #ifdef __cplusplus extern "C" { #endif /* * Argument kinds. */ typedef enum { argFlag, /* flag (present / not-present) */ /* [val: bool *] */ argInt, /* integer arg */ /* [val: int *] */ argFP, /* floating point arg */ /* [val: double *] */ argString, /* string arg */ /* [val: char *] */ /* obsolete arguments -- these produce an error and aren't */ /* included in the usage listing */ argObsolete, /* no argument */ argObsolete1, /* one argument */ /* dummy entries -- these show up in the usage listing only; */ /* useful for X args, for example */ argFlagDummy, argIntDummy, argFPDummy, argStringDummy } ArgKind; /* * Argument descriptor. */ typedef struct { const char *arg; /* the command line switch */ ArgKind kind; /* kind of arg */ void *val; /* place to store value */ int size; /* for argString: size of string */ const char *usage; /* usage string */ } ArgDesc; /* * Parse command line. Removes all args which are found in the arg * descriptor list . Stops parsing if "--" is found (and removes * it). Returns false if there was an error. */ extern bool parseArgs(ArgDesc *args, int *argc, char *argv[]); /* * Print usage message, based on arg descriptor list. */ extern void printUsage(const char *program, const char *otherArgs, ArgDesc *args); /* * Check if a string is a valid integer or floating point number. */ extern bool isInt(char *s); extern bool isFP(char *s); #ifdef __cplusplus } #endif #endif