goptions
Loading...
Searching...
No Matches
goptions.h
Go to the documentation of this file.
1
6#pragma once
7
8#include "goption.h"
9#include "gswitch.h"
10
11// gemc
12#include <gemc/guts/gutsConventions.h>
13
14
15// c++
16#include <string>
17#include <fstream>
18#include <iostream>
19#include <map>
20#include <utility>
21#include <vector>
22
46{
47public:
57 };
58
69 explicit GOptions(std::string name) : option_verbosity_name(name) { addOptionTitle(std::move(name)); }
70
86 GOptions(int argc, char* argv[], const GOptions& user_defined_options = GOptions());
87
88
97 if (yamlConf != nullptr) {
98 if (yamlConf->is_open()) { yamlConf->close(); }
99 delete yamlConf;
100 yamlConf = nullptr;
101 }
102 }
103
118 void defineSwitch(const std::string& name, const std::string& description);
119
130 void defineOption(const GVariable& gvar, const std::string& help);
131
145 void defineOption(const std::string& name, const std::string& description, const std::vector<GVariable>& gvars,
146 const std::string& help);
147
157 [[nodiscard]] int getScalarInt(const std::string& tag) const;
158
159
166 [[nodiscard]] double getScalarDouble(const std::string& tag) const;
167
179 [[nodiscard]] std::string getScalarString(const std::string& tag) const;
180
187 [[nodiscard]] bool getSwitch(const std::string& tag) const;
188
206 [[nodiscard]] inline YAML::Node getOptionNode(const std::string& tag) const {
207 if (!doesOptionExist(tag)) {
208 std::cerr << "Option " << tag << " does not exist. Exiting." << std::endl;
210 }
211 return getOptionIterator(tag)->value.begin()->second;
212 }
213
228 [[nodiscard]] YAML::Node getOptionMapInNode(const std::string& option_name, const std::string& map_key) const;
229
240 void setOptionValueFromString(const std::string& optionName, const std::string& possibleYamlNode);
241
252 [[nodiscard]] int getVerbosityFor(const std::string& tag) const;
253
265 [[nodiscard]] int getDebugFor(const std::string& tag) const;
266
272 [[nodiscard]] const std::vector<GOption>& getOptions() const { return goptions; }
273
279 [[nodiscard]] const std::map<std::string, GSwitch>& getSwitches() const { return switches; }
280
298 inline void addGOptions(const GOptions& src) {
299 // 1. Options – check by option name
300 for (const auto& opt : src.getOptions()) {
301 auto already = std::find_if(
302 goptions.begin(), goptions.end(),
303 [&opt](const GOption& o) { return o.name == opt.name; });
304
305 if (already == goptions.end())
306 goptions.push_back(opt); // add only if absent
307 }
308
309 // 2. Switches – std::map::insert does the uniqueness check for us
310 for (const auto& sw : src.getSwitches()) {
311 switches.insert(sw); // ignored if key already exists
312 }
313
314 // 3. Verbosity/debug variable names – store each only once
315 for (const auto& v : src.option_verbosity_names) {
316 auto same = std::find_if(
318 [&v](const GVariable& existing) { return existing.name == v.name; });
319
320 if (same == option_verbosity_names.end())
321 option_verbosity_names.push_back(v);
322 }
323 }
324
333
341 std::vector<GVariable> option_verbosity_names;
342
343 inline void addOptionTitle(const std::string& name) {
344 std::string option_verbosity_name_desc = name + " verbosity level or debug switch";
346 }
347
361 template <typename T>
362 T get_variable_in_option(const YAML::Node& node, const std::string& variable_name, const T& default_value);
363
374 [[nodiscard]] std::vector<std::string> getYamlFiles() const { return yaml_files; }
375
382 [[nodiscard]] bool doesOptionExist(const std::string& tag) const;
383
384private:
385 std::vector<GOption> goptions;
386 std::map<std::string, GSwitch> switches;
387 std::ofstream* yamlConf{};
388 std::string executableName;
389 std::string executableCallingDir;
391 std::string installDir;
392 std::vector<std::string> yaml_files;
393
394 std::vector<std::string> findYamls(int argc, char* argv[]);
395 void setOptionsValuesFromYamlFile(const std::string& yaml);
396 void setOptionValuesFromCommandLineArgument(const std::string& optionName, const std::string& possibleYamlNode);
397 std::vector<GOption>::iterator getOptionIterator(const std::string& name);
398 [[nodiscard]] std::vector<GOption>::const_iterator getOptionIterator(const std::string& name) const;
399 void printOptionOrSwitchHelp(const std::string& tag) const;
400 void printSearch(const std::string& tag) const;
401 void printHelp() const;
402 void printWebHelp() const;
403 void saveOptions() const;
404 void print_version();
405};
406
408GOptions& operator+=(GOptions& original, const GOptions& optionsToAdd);
Stores one configuration option (scalar or structured), including schema defaults and current value.
Definition goption.h:105
Parses, stores, and exposes command-line options and YAML configuration values.
Definition goptions.h:46
std::string option_verbosity_name
Name used when constructing the verbosity/debug schema helper.
Definition goptions.h:332
bool getSwitch(const std::string &tag) const
Retrieves the status of a switch.
Definition goptions.cc:466
const std::vector< GOption > & getOptions() const
Returns the list of defined options.
Definition goptions.h:272
YAML::Node getOptionNode(const std::string &tag) const
Retrieves the YAML node for the specified option.
Definition goptions.h:206
void addOptionTitle(const std::string &name)
Definition goptions.h:343
GOptions(std::string name)
Constructor for creating verbosity/debug schema helpers.
Definition goptions.h:69
void setOptionValueFromString(const std::string &optionName, const std::string &possibleYamlNode)
Updates an option value from a YAML-formatted string.
Definition goptions.cc:448
~GOptions()
Destructor.
Definition goptions.h:96
void defineSwitch(const std::string &name, const std::string &description)
Defines and adds a command-line switch.
Definition goptions.cc:227
std::string getScalarString(const std::string &tag) const
Retrieves the value of a scalar string option.
Definition goptions.cc:287
GOptions()
Default constructor.
Definition goptions.h:56
void defineOption(const GVariable &gvar, const std::string &help)
Defines and adds a scalar option.
Definition goptions.cc:239
YAML::Node getOptionMapInNode(const std::string &option_name, const std::string &map_key) const
Retrieves a map entry value from a structured option stored as a sequence of maps.
Definition goptions.cc:479
T get_variable_in_option(const YAML::Node &node, const std::string &variable_name, const T &default_value)
Retrieves a typed variable from a YAML node within an option.
Definition goptions.cc:497
double getScalarDouble(const std::string &tag) const
Retrieves the value of a scalar double option.
Definition goptions.cc:276
bool doesOptionExist(const std::string &tag) const
Checks if an option exists.
Definition goptions.cc:373
int getScalarInt(const std::string &tag) const
Retrieves the value of a scalar integer option.
Definition goptions.cc:265
std::vector< std::string > getYamlFiles() const
Returns the list of YAML file paths detected on the command line.
Definition goptions.h:374
void addGOptions(const GOptions &src)
Merges options and switches from another GOptions : into this one.
Definition goptions.h:298
const std::map< std::string, GSwitch > & getSwitches() const
Returns the map of defined switches.
Definition goptions.h:279
int getDebugFor(const std::string &tag) const
Retrieves the debug level for the specified tag.
Definition goptions.cc:529
int getVerbosityFor(const std::string &tag) const
Retrieves the verbosity level for the specified tag.
Definition goptions.cc:515
std::vector< GVariable > option_verbosity_names
Schema entries used to define the verbosity and debug structured options.
Definition goptions.h:341
Definitions of GVariable : and GOption : used by GOptions : .
#define EC__NOOPTIONFOUND
Option/switch/key not found, or invalid command-line token.
GOptions & operator+=(GOptions &original, const GOptions &optionsToAdd)
Overloaded operator to add options and switches from one GOptions : to another.
Definition goptions.cc:644
Definition of GSwitch : the boolean command-line switch type used by GOptions : .
#define UNINITIALIZEDSTRINGQUANTITY
Describes a schema entry: key name, default value, and user-facing description.
Definition goption.h:34