source: src/UIElements/CommandLineUI/CommandLineParser.hpp@ adbeca

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since adbeca was 7912e9, checked in by Frederik Heber <heber@…>, 11 years ago

CommandLineParser adds Action's default values as implicit.

  • this allows to have action's token as option with both empty (then default is used) and some given argument.
  • Property mode set to 100644
File size: 3.5 KB
Line 
1/*
2 * CommandLineParser.hpp
3 *
4 * Created on: May 8, 2010
5 * Author: heber
6 */
7
8#ifndef COMMANDLINEPARSER_HPP_
9#define COMMANDLINEPARSER_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16
17#include <boost/program_options.hpp>
18
19namespace po = boost::program_options;
20
21#include "CodePatterns/Singleton.hpp"
22#include "UIElements/CommandLineUI/TypeEnumContainer.hpp"
23
24#include <map>
25
26namespace MoleCuilder {
27 class Action;
28 class OptionTrait;
29}
30class CommandLineParser_ActionRegistry_ConsistenyTest;
31
32/** This class is a wrapper for boost::program_options.
33 *
34 */
35class CommandLineParser : public Singleton<CommandLineParser> {
36 friend class Singleton<CommandLineParser>;
37
38 //!> test needs to access CmdParserLookup to see whether menus are missing
39 friend class CommandLineParser_ActionRegistry_ConsistencyTest;
40public:
41
42 // Parses the command line arguments in CommandLineParser::**argv with currently known options.
43 void Run(int _argc, char **_argv);
44
45 // Initialises all options from ActionRegistry.
46 void InitializeCommandArguments();
47
48 // Checks whether there have been any commands on the command line.
49 bool isEmpty();
50
51 /* boost's program_options are sorted into three categories:
52 * -# generic options: option available to both command line and config
53 * -# config options: only available in the config file
54 * -# hidden options: options which the user is not shown on "help"
55 */
56 po::options_description analysis;
57 po::options_description atom;
58 po::options_description bond;
59 po::options_description command;
60 po::options_description edit;
61 po::options_description fill;
62 po::options_description shape;
63 po::options_description fragmentation;
64 po::options_description graph;
65 po::options_description molecule;
66 po::options_description options;
67 po::options_description parser;
68 po::options_description potential;
69 po::options_description selection;
70 po::options_description tesselation;
71 po::options_description world;
72
73 po::options_description visible;
74
75 po::variables_map vm;
76
77 // private sequence of actions as they appeared on the command line
78 std::list<std::string> SequenceOfActions;
79
80private:
81 // private constructor and destructor
82 CommandLineParser();
83 virtual ~CommandLineParser();
84
85 /* The following program_options options_decriptions are used to
86 * generate the various cases and call differently in Parse().
87 */
88 po::options_description cmdline_options;
89 po::options_description config_file_options;
90
91 // adds options to the parser
92 void AddOptionToParser(
93 const MoleCuilder::OptionTrait * const currentOption,
94 po::options_description* OptionList,
95 const bool _DefaultAsImplicit);
96
97 // creates a map from short forms to action tokens needed to parse command line
98 std::map <std::string, std::string> getShortFormToActionMap() const;
99
100 typedef std::map< std::string , po::options_description *> CmdParserLookupMap;
101
102 // lookup list from "configmenus" to the ones of CommandLineParser
103 CmdParserLookupMap CmdParserLookup;
104
105 // Sets the options from the three cases.
106 void setOptions(int _argc, char **_argv);
107
108 // Parses all options from command line and config file
109 bool Parse();
110
111 // as boost's program_options does not care about of order of appearance but we do for actions,
112 // we have to have a list and a function to obtain it.
113 void scanforSequenceOfArguments();
114
115 TypeEnumContainer TypeToEnums;
116
117 // argument counter and array passed on from main()
118 int argc;
119 char **argv;
120};
121
122#endif /* COMMANDLINEPARSER_HPP_ */
Note: See TracBrowser for help on using the repository browser.