mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-24 23:30:03 +02:00
Command proxy (#25)
* added cmd proxy * minor * minor * WIP * clean up * added comment
This commit is contained in:
parent
85d4dfc7c8
commit
788ad8d3b6
@ -3,6 +3,7 @@
|
||||
#include <string>
|
||||
|
||||
#include "CmdLineParser.h"
|
||||
#include "CmdProxy.h"
|
||||
#include "container_utils.h"
|
||||
#include "string_utils.h"
|
||||
#include "multiSlsDetector.h"
|
||||
@ -88,6 +89,18 @@ class multiSlsDetectorClient {
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
//Call CmdProxy which execute the command if it exists, on success returns an empty string
|
||||
//If the command is not in CmdProxy but deprecated the new command is returned
|
||||
sls::CmdProxy<multiSlsDetector> proxy(detPtr);
|
||||
auto cmd = proxy.Call(parser.command(), parser.arguments(), parser.detector_id());
|
||||
if (cmd.empty())
|
||||
return;
|
||||
else
|
||||
parser.setCommand(cmd);
|
||||
|
||||
|
||||
|
||||
// call multi detector command line
|
||||
slsDetectorCommand myCmd(detPtr);
|
||||
std::string answer = myCmd.executeLine(parser.n_arguments()+1, parser.argv().data(), action_, parser.detector_id());
|
||||
|
@ -26,8 +26,5 @@ int main(int argc, char *argv[]) {
|
||||
#ifdef HELP
|
||||
int action = slsDetectorDefs::HELP_ACTION;
|
||||
#endif
|
||||
|
||||
// if (argc > 1)
|
||||
// argv++;
|
||||
multiSlsDetectorClient(argc, argv, action);
|
||||
}
|
||||
|
@ -14,6 +14,7 @@ class CmdLineParser {
|
||||
int detector_id() const { return detector_id_; };
|
||||
int n_arguments() const { return arguments_.size(); }
|
||||
const std::string &command() const { return command_; }
|
||||
void setCommand(std::string cmd){command_ = cmd;}
|
||||
const std::string &executable() const { return executable_; }
|
||||
const std::vector<std::string> &arguments() const { return arguments_; };
|
||||
std::vector<const char *> argv() const;
|
||||
|
100
slsSupportLib/include/CmdProxy.h
Normal file
100
slsSupportLib/include/CmdProxy.h
Normal file
@ -0,0 +1,100 @@
|
||||
#pragma once
|
||||
|
||||
#include <iostream>
|
||||
#include <map>
|
||||
#include <sstream>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
#include "logger.h"
|
||||
#include "sls_detector_exceptions.h"
|
||||
|
||||
namespace sls {
|
||||
|
||||
template <typename T> class CmdProxy {
|
||||
public:
|
||||
explicit CmdProxy(T *detectorPtr) : det(detectorPtr) {}
|
||||
|
||||
std::string Call(const std::string &command,
|
||||
const std::vector<std::string> &arguments,
|
||||
int detector_id) {
|
||||
cmd = command;
|
||||
args = arguments;
|
||||
det_id = detector_id;
|
||||
|
||||
ReplaceIfDepreciated(cmd);
|
||||
|
||||
auto it = functions.find(cmd);
|
||||
if (it != functions.end()) {
|
||||
std::cout << ((*this).*(it->second))();
|
||||
return {};
|
||||
} else {
|
||||
return cmd;
|
||||
}
|
||||
}
|
||||
|
||||
bool ReplaceIfDepreciated(std::string &command) {
|
||||
auto d_it = depreciated_functions.find(command);
|
||||
if (d_it != depreciated_functions.end()) {
|
||||
FILE_LOG(logWARNING)
|
||||
<< "WARNING: " << command
|
||||
<< " is depreciated and will be removed. Please migrate to: "
|
||||
<< d_it->second;
|
||||
command = d_it->second;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
size_t GetFunctionMapSize() const noexcept { return functions.size(); };
|
||||
|
||||
private:
|
||||
T *det;
|
||||
std::string cmd;
|
||||
std::vector<std::string> args;
|
||||
int det_id{-1};
|
||||
|
||||
using FunctionMap = std::map<std::string, std::string (CmdProxy::*)()>;
|
||||
using StringMap = std::map<std::string, std::string>;
|
||||
|
||||
// Initialize maps for translating name and function
|
||||
FunctionMap functions{{"newfunc", &CmdProxy::NewFunction}};
|
||||
|
||||
StringMap depreciated_functions{{"oldvrfcmd", "vrf"},
|
||||
{"veryveryold", "vcp"},
|
||||
{"anothercmd", "vrs"},
|
||||
{"this_as_well", "enablefwrite"}};
|
||||
|
||||
|
||||
template <typename U> std::string ResultToString(const U &ret) {
|
||||
std::ostringstream os;
|
||||
if (det_id != -1)
|
||||
os << det_id << ":";
|
||||
os << cmd << " " << ret << "\n";
|
||||
return os.str();
|
||||
}
|
||||
|
||||
void WrongNumberOfParameters(size_t expected) {
|
||||
throw RuntimeError("ERROR: Expected " + std::to_string(expected) +
|
||||
" parameters but got " + std::to_string(args.size()) +
|
||||
"\n");
|
||||
}
|
||||
|
||||
// Mapped functions
|
||||
|
||||
//example
|
||||
std::string NewFunction() {
|
||||
if(args.size() == 0){
|
||||
std::cout << "This is the new function function\n";
|
||||
return ResultToString(det->setExposureTime(-1, true));
|
||||
}else if(args.size() == 1){
|
||||
std::cout << "Setting exposure time to " << args[0] << "s\n";
|
||||
return ResultToString(det->setExposureTime(std::stod(args[0]), true, det_id));
|
||||
}else{
|
||||
WrongNumberOfParameters(1);
|
||||
return {};
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace sls
|
Loading…
x
Reference in New Issue
Block a user