23#include <unordered_map>
33 jevois::
Component(instanceID), itsCommandLineArgs((char const **)(argv), (char const **)(argv+argc)),
40 itsCommandLineArgs = std::vector<std::string>((
char const **)(argv), (
char const **)(argv+argc));
51 if (itsGotArgs ==
false)
52 LERROR(
"No command-line arguments given; did you forget to call jevois::Manager::setArgs()?");
54 if (itsCommandLineArgs.size() > 0) itsRemainingArgs = parseCommandLine(itsCommandLineArgs);
65 if (help::get()) { printHelpMessage();
LINFO(
"JeVois: exit after help message"); exit(0); }
74#if !defined(JEVOIS_TRACE_ENABLE) || !defined(JEVOIS_LDEBUG_ENABLE)
75 tracelevel::freeze(
true);
82 constructHelpMessage(std::cout);
88 std::unordered_map<std::string,
89 std::unordered_map<std::string,
90 std::vector<std::pair<std::string,
94 this->populateHelpMessage(
"", helplist,
false);
99 boost::shared_lock<boost::shared_mutex> lck(itsSubMtx);
100 for (std::shared_ptr<jevois::Component> c : itsSubComponents) c->populateHelpMessage(
"", helplist);
104 if (helplist.empty()) { out <<
"NO PARAMETERS.";
return; }
106 out <<
"PARAMETERS:" << std::endl << std::endl;
108 for (
auto & c : helplist)
111 out << c.first << std::endl;
114 for (
auto const & n : c.second)
116 out << n.first << std::endl;
120 out <<
" Exported By: ";
121 for (
auto const & cp : n.second)
124 if (cp.second.empty() ==
false) out <<
" value=[" << cp.second <<
']';
125 if (cp != *(n.second.end()-1)) out <<
", ";
137std::vector<std::string>
const jevois::Manager::parseCommandLine(std::vector<std::string>
const & commandLineArgs)
140 std::vector<std::string> remainingArgs;
141 remainingArgs.push_back(commandLineArgs[0]);
144 std::vector<std::string>::const_iterator argIt;
145 for (argIt = commandLineArgs.begin() + 1; argIt != commandLineArgs.end(); ++argIt)
148 if (argIt->length() < 2 || (*argIt)[0] !=
'-' || (*argIt)[1] !=
'-') { remainingArgs.push_back(*argIt);
continue; }
151 if (*argIt ==
"--")
break;
154 size_t const equalsPos = argIt->find_first_of(
'=');
155 if (equalsPos < 3)
LFATAL(
"Cannot parse command-line argument with no name [" << *argIt <<
']');
157 std::string
const parameterName = argIt->substr(2, equalsPos - 2);
158 std::string
const parameterValue = (equalsPos == std::string::npos) ?
"true" : argIt->substr(equalsPos + 1);
162 setParamString(parameterName, parameterValue);
166 while (argIt != commandLineArgs.end()) { remainingArgs.push_back(*argIt); ++argIt; }
168 return remainingArgs;
173{
return itsRemainingArgs; }
180 boost::upgrade_lock<boost::shared_mutex> uplck(itsSubMtx);
182 for (
auto itr = itsSubComponents.begin(); itr != itsSubComponents.end(); ++itr)
183 if ((*itr)->instanceName() == instance)
185 doRemoveSubComponent(itr, uplck,
"Component");
189 if (warnIfNotFound)
LERROR(
"Component [" << instance <<
"] not found. Ignored.");
201#ifdef JEVOIS_LDEBUG_ENABLE
210#if !defined(JEVOIS_TRACE_ENABLE) || !defined(JEVOIS_LDEBUG_ENABLE)
212 LERROR(
"Debug trace has been disabled at compile-time, re-compile with -DJEVOIS_LDEBUG_ENABLE=ON and "
213 "-DJEVOIS_TRACE_ENABLE=ON to see trace info");
A component of a model hierarchy.
void setCommandLineArgs(int argc, char const *argv[])
Set the command-line arguments, call this before start() if args were not passed at construction.
void removeComponent(std::shared_ptr< Comp > &component)
Remove a top-level Component from the Manager, by shared_ptr.
void onParamChange(manager::loglevel const ¶m, manager::LogLevel const &newval) override
Parameter callback.
void postInit() override
Checks for the –help flag.
virtual ~Manager()
Destructor.
void constructHelpMessage(std::ostream &out) const
Constructs a help message from all parameters in the model, and outputs it to 'out'.
std::vector< std::string > const & remainingArgs() const
Get the remaining arguments that were not parsed by the command line.
void printHelpMessage() const
Constructs a help message and tries to send it to /usr/bin/less.
void preInit() override
Calls parseCommandLine()
int logLevel
Current log level.
#define LFATAL(msg)
Convenience macro for users to print out console or syslog messages, FATAL level.
int traceLevel
Current trace level.
#define LERROR(msg)
Convenience macro for users to print out console or syslog messages, ERROR level.
#define LINFO(msg)
Convenience macro for users to print out console or syslog messages, INFO level.
Main namespace for all JeVois classes and functions.