| 1 |
#include <iostream> |
| 2 |
#include <string> |
| 3 |
|
| 4 |
#include "CmdLineParser.h" |
| 5 |
|
| 6 |
|
| 7 |
using std::string; |
| 8 |
using namespace FCUtils; |
| 9 |
|
| 10 |
int main(int argc, char ** argv ){ |
| 11 |
|
| 12 |
// A simple program to explain the usage of the CmdLineParser in |
| 13 |
// DEFINE mode, i.e. the options are not defined in the main. The command |
| 14 |
// line options them self are used to define and to update the value used in |
| 15 |
// the Options map singleton. Note that no help can be defined |
| 16 |
|
| 17 |
// First of all get the singleton with the option map |
| 18 |
Options *provaopt=Options::Get(); |
| 19 |
// print the help. We are in DEFINE mode, no options have been |
| 20 |
// definited the Options singleton will be empty |
| 21 |
provaopt->Help(); |
| 22 |
// print the values in the option map. Same as for the help |
| 23 |
provaopt->Print(); |
| 24 |
|
| 25 |
cout << endl << "++++++++ After CmdLineParser creation +++++++" << endl; |
| 26 |
// Create the parser object in DEFINE (default) mode, i.e. the |
| 27 |
// options will be definited reading them from the command line. |
| 28 |
CmdLineParser test(argc,argv); |
| 29 |
// Print the values as entered |
| 30 |
test.Print(); |
| 31 |
// Move the entered values to the Options singleton |
| 32 |
test.MoveToOptions(); |
| 33 |
|
| 34 |
// Print the help again |
| 35 |
provaopt->Help(); |
| 36 |
// Print the values as entered by command line |
| 37 |
provaopt->Print(); |
| 38 |
|
| 39 |
// Get the value from the option using various way |
| 40 |
|
| 41 |
// Use the GeOption methods of the Options class |
| 42 |
string ps; |
| 43 |
provaopt->GetOption("file") >> ps; |
| 44 |
std::cout << " The filename : " << ps << endl; |
| 45 |
|
| 46 |
// Use the [] operator |
| 47 |
Options &popt=*Options::Get(); |
| 48 |
popt["file"] >> ps; |
| 49 |
std::cout << " The filename : " << ps << endl; |
| 50 |
|
| 51 |
return 0; |
| 52 |
|
| 53 |
|
| 54 |
} |