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 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138
|
/******************************************************************************
**
** bin2txt.cpp
**
** Fri Jul 27 20:02:39 2001
** Linux 2.4.4 (#2 SMP Thu Jul 5 10:45:01 CEST 2001) i686
** martin@linux. (Martin Bickel)
**
** Definition of command line parser class
**
** Automatically created by genparse v0.5.2
**
** See http://genparse.sourceforge.net/ for details and updates
**
******************************************************************************/
#include <getopt.h>
#include <stdlib.h>
#include "bin2txt.h"
/*----------------------------------------------------------------------------
**
** Cmdline::Cmdline()
**
** Constructor method.
**
**--------------------------------------------------------------------------*/
Cmdline::Cmdline(int argc, char *argv[]) throw (string)
{
extern char *optarg;
extern int optind;
int option_index = 0;
int c;
static struct option long_options[] =
{
{"configfile", 1, 0, 'c'},
{"verbose", 1, 0, 'r'},
{"help", 0, 0, 'h'},
{"version", 0, 0, 'v'},
{0, 0, 0, 0}
};
_executable += argv[0];
/* default values */
_r = 0;
_h = false;
_v = false;
while ((c = getopt_long(argc, argv, "c:r:hv", long_options, &option_index)) != EOF)
{
switch(c)
{
case 'c':
_c = optarg;
break;
case 'r':
_r = atoi(optarg);
if (_r < 0)
{
string s;
s += "parameter range error: r must be >= 0";
throw(s);
}
if (_r > 10)
{
string s;
s += "parameter range error: r must be <= 10";
throw(s);
}
break;
case 'h':
_h = true;
this->usage();
break;
case 'v':
_v = true;
break;
default:
this->usage();
}
} /* while */
_optind = optind;
}
/*----------------------------------------------------------------------------
**
** Cmdline::usage()
**
** Usage function.
**
**--------------------------------------------------------------------------*/
void Cmdline::usage()
{
cout << "converts ASCs binary file formats to the new plaintext formats " << endl;
cout << "usage: " << _executable << " [ -crhv ] FILES [...]" << endl;
cout << " [ -c ] ";
cout << "[ --configfile ] ";
cout << "(";
cout << "type=";
cout << "STRING";
cout << ")\n";
cout << " Use given configuration file\n";
cout << " [ -r ] ";
cout << "[ --verbose ] ";
cout << "(";
cout << "type=";
cout << "INTEGER,";
cout << " range=0...10,";
cout << " default=0";
cout << ")\n";
cout << " Set verbosity level to x (0..10)\n";
cout << " [ -h ] ";
cout << "[ --help ] ";
cout << "(";
cout << "type=";
cout << "FLAG";
cout << ")\n";
cout << " Display help information.\n";
cout << " [ -v ] ";
cout << "[ --version ] ";
cout << "(";
cout << "type=";
cout << "FLAG";
cout << ")\n";
cout << " Output version.\n";
exit(0);
}
|