9#include <framework/database/DBImportObjPtr.h>
10#include <trg/cdc/dbobjects/CDCTriggerNeuroConfig.h>
16 InputParser(
const int& argc,
char** argv)
18 for (
int i = 1; i < argc; ++i)
19 this->tokens.push_back(std::string(argv[i]));
21 const std::string& getCmdOption(
const std::string& option)
const
23 std::vector<std::string>::const_iterator itr;
24 itr = std::find(this->tokens.begin(), this->tokens.end(), option);
25 if (itr != this->tokens.end() && ++itr != this->tokens.end()) {
28 static const std::string empty_string(
"");
31 bool cmdOptionExists(
const std::string& option)
const
33 return std::find(this->tokens.begin(), this->tokens.end(), option)
34 != this->tokens.end();
37 std::vector <std::string> tokens;
42int main(
int argc,
char** argv)
49 std::string configfilename =
"";
57 std::string datastorename =
"";
60 if (input.cmdOptionExists(
"-h")) {
61 std::cout <<
"A small tool to create ConDB payloads for the Neurotrigger." << std::endl;
62 std::cout <<
"Usage: \% trg-cdc-neurotrigger-writedb -f example.conf -n exmaple" << std::endl;
64 const std::string& filename = input.getCmdOption(
"-f");
65 if (!filename.empty()) {
66 configfilename = filename;
69 const std::string& storename = input.getCmdOption(
"-n");
70 if (!storename.empty()) {
71 datastorename = storename;
77 std::ifstream confile;
79 confile.open(configfilename, std::ifstream::in);
81 std::cout <<
"ERROR! While opening file: " << configfilename <<
" Error code: " << e << std::endl;
85 if (!confile.is_open()) {
86 std::cout <<
"ERROR! While opening file: " << configfilename << std::endl;
89 while (std::getline(confile, line_all)) {
90 std::size_t hashtag = line_all.find(
'#');
91 std::string line = line_all.substr(0, hashtag);
94 if (line.length() < 3) {
98 if (line.find(
'=') == std::string::npos) {
101 par = line.substr(0, line.find(
'='));
102 par.erase(std::remove(par.begin(), par.end(),
' '), par.end());
104 if (par ==
"nniov_run_start") {
105 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
106 nniov_run_start = std::stoi(key);
109 if (par ==
"nniov_run_end") {
110 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
111 nniov_run_end = std::stoi(key);
114 if (par ==
"nniov_exp_start") {
115 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
116 nniov_exp_start = std::stoi(key);
119 if (par ==
"nniov_exp_end") {
120 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
121 nniov_exp_end = std::stoi(key);
124 if (par ==
"nnname") {
126 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
129 nc->setNNName(nnname);
131 if (par ==
"nnnote") {
133 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
136 nc->setNNNotes(nnnote);
138 if (par ==
"nnpath") {
140 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
143 nc->loadMLPs(nnpath,
"MLPs");
145 if (par ==
"fwname") {
147 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
150 nc->setNNTFirmwareVersionID(fwname);
152 if (par ==
"fwnote") {
154 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
157 nc->setNNTFirmwareComment(fwnote);
160 if (par ==
"ppnote") {
162 key = line.substr((line.find(
'"') + 1), (line.find(
'"', line.find(
'"') + 1) - 1 - line.find(
'"')));
165 nc->setPPNotes(ppnote);
167 if (par ==
"ppbool") {
168 if (line.find(
"alse") != std::string::npos) {
170 }
else if (line.find(
"rue") != std::string::npos) {
173 std::cout <<
"ERROR!: Wrong key argument for parameter ppbool:" << line << std::endl;
176 nc->setUseETF(ppbool);
178 if (par ==
"addb2formatline") {
180 std::stringstream ss;
181 ss << line.substr((line.find(
'(') + 1), (line.find(
')') - 1 - line.find(
'(')));
183 std::string startstr;
185 std::string offsetstr;
186 std::string description;
187 std::getline(ss, uid,
',');
188 std::getline(ss, startstr,
',');
189 std::getline(ss, endstr,
',');
190 std::getline(ss, offsetstr,
',');
191 std::getline(ss, description,
'\n');
192 nc->addB2FormatLine(std::stoi(startstr), std::stoi(endstr), std::stoi(offsetstr), uid.substr((uid.find(
'"') + 1), (uid.find(
'"',
193 uid.find(
'"') + 1) - 1 - uid.find(
'"'))), description.substr((description.find(
'"') + 1), (description.find(
'"',
194 description.find(
'"') + 1) - 1 - description.find(
'"'))));
200 IntervalOfValidity iov(nniov_exp_start, nniov_run_start, nniov_exp_end, nniov_run_end);
Class for importing a single object to the database.
A class that describes the interval of experiments/runs for which an object in the database is valid.
Abstract base class for different kinds of events.