317 lines
10 KiB
C++
317 lines
10 KiB
C++
/** @file
|
|
* @author Edouard DUPIN
|
|
* @copyright 2016, Edouard DUPIN, all right reserved
|
|
* @license APACHE v2.0 (see license file)
|
|
*/
|
|
#include <jus/AbstractFunction.h>
|
|
#include <jus/debug.h>
|
|
namespace jus {
|
|
template<> bool convertJsonTo<bool>(const ejson::Value& _value) {
|
|
return _value.toBoolean().get();
|
|
}
|
|
template<> std::vector<bool> convertJsonTo<std::vector<bool>>(const ejson::Value& _value) {
|
|
std::vector<bool> out;
|
|
for (const auto it : _value.toArray()) {
|
|
out.push_back(convertJsonTo<bool>(it));
|
|
}
|
|
return out;
|
|
}
|
|
template<> float convertJsonTo<float>(const ejson::Value& _value) {
|
|
return _value.toNumber().get();
|
|
}
|
|
template<> double convertJsonTo<double>(const ejson::Value& _value) {
|
|
return _value.toNumber().get();
|
|
}
|
|
template<> int64_t convertJsonTo<int64_t>(const ejson::Value& _value) {
|
|
return int64_t(_value.toNumber().get());
|
|
}
|
|
template<> int32_t convertJsonTo<int32_t>(const ejson::Value& _value) {
|
|
return int32_t(_value.toNumber().get());
|
|
}
|
|
template<> int16_t convertJsonTo<int16_t>(const ejson::Value& _value) {
|
|
return int16_t(_value.toNumber().get());
|
|
}
|
|
template<> int8_t convertJsonTo<int8_t>(const ejson::Value& _value) {
|
|
return int8_t(_value.toNumber().get());
|
|
}
|
|
template<> uint64_t convertJsonTo<uint64_t>(const ejson::Value& _value) {
|
|
return uint64_t(_value.toNumber().get());
|
|
}
|
|
template<> uint32_t convertJsonTo<uint32_t>(const ejson::Value& _value) {
|
|
return uint32_t(_value.toNumber().get());
|
|
}
|
|
template<> uint16_t convertJsonTo<uint16_t>(const ejson::Value& _value) {
|
|
return uint16_t(_value.toNumber().get());
|
|
}
|
|
template<> uint8_t convertJsonTo<uint8_t>(const ejson::Value& _value) {
|
|
return uint8_t(_value.toNumber().get());
|
|
}
|
|
template<> std::string convertJsonTo<std::string>(const ejson::Value& _value) {
|
|
return _value.toString().get();
|
|
}
|
|
template<> std::vector<std::string> convertJsonTo<std::vector<std::string>>(const ejson::Value& _value) {
|
|
std::vector<std::string> out;
|
|
for (const auto it : _value.toArray()) {
|
|
out.push_back(convertJsonTo<std::string>(it));
|
|
}
|
|
return out;
|
|
}
|
|
template<> jus::File convertJsonTo<jus::File>(const ejson::Value& _value) {
|
|
ejson::Object obj = _value.toObject();
|
|
jus::File out;
|
|
out.setMineType(obj["mine-type"].toString().get());
|
|
out.preSetDataSize(obj["size"].toNumber().getU64());
|
|
//out.add("type", ejson::String("file"));
|
|
// TODO : Add extended datas ...
|
|
return out;
|
|
}
|
|
|
|
template<> ejson::Value convertToJson<bool>(const bool& _value) {
|
|
return ejson::Boolean(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<std::vector<bool>>(const std::vector<bool>& _value) {
|
|
ejson::Array out;
|
|
for (const auto &it : _value) {
|
|
out.add(ejson::Boolean(it));
|
|
}
|
|
return out;
|
|
}
|
|
template<> ejson::Value convertToJson<float>(const float& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<double>(const double& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<int64_t>(const int64_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<int32_t>(const int32_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<int16_t>(const int16_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<int8_t>(const int8_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<uint64_t>(const uint64_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<uint32_t>(const uint32_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<uint16_t>(const uint16_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<uint8_t>(const uint8_t& _value) {
|
|
return ejson::Number(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<std::string>(const std::string& _value) {
|
|
return ejson::String(_value);
|
|
}
|
|
template<> ejson::Value convertToJson<std::vector<std::string>>(const std::vector<std::string>& _value) {
|
|
ejson::Array out;
|
|
for (auto &it : _value) {
|
|
out.add(ejson::String(it));
|
|
}
|
|
return out;
|
|
}
|
|
template<> ejson::Value convertToJson<jus::FileServer>(const jus::FileServer& _value) {
|
|
ejson::Array out;
|
|
/*
|
|
for (auto &it : _value) {
|
|
out.add(ejson::String(it));
|
|
}
|
|
*/
|
|
return out;
|
|
}
|
|
template<> ejson::Value convertToJson<jus::File>(const jus::File& _value) {
|
|
ejson::Object out;
|
|
out.add("type", ejson::String("file"));
|
|
out.add("mine-type", ejson::String(_value.getMineType()));
|
|
out.add("size", ejson::Number(_value.getData().size()));
|
|
// TODO : Add extended datas ...
|
|
return out;
|
|
}
|
|
|
|
template<> bool convertStringTo<bool>(const std::string& _value) {
|
|
return etk::string_to_bool(_value);
|
|
}
|
|
template<> float convertStringTo<float>(const std::string& _value) {
|
|
return etk::string_to_float(_value);
|
|
}
|
|
template<> double convertStringTo<double>(const std::string& _value) {
|
|
return etk::string_to_double(_value);
|
|
}
|
|
template<> int64_t convertStringTo<int64_t>(const std::string& _value) {
|
|
return etk::string_to_int64_t(_value);
|
|
}
|
|
template<> int32_t convertStringTo<int32_t>(const std::string& _value) {
|
|
return etk::string_to_int32_t(_value);
|
|
}
|
|
template<> int16_t convertStringTo<int16_t>(const std::string& _value) {
|
|
return etk::string_to_int16_t(_value);
|
|
}
|
|
template<> int8_t convertStringTo<int8_t>(const std::string& _value) {
|
|
return etk::string_to_int8_t(_value);
|
|
}
|
|
template<> uint64_t convertStringTo<uint64_t>(const std::string& _value) {
|
|
return etk::string_to_uint64_t(_value);
|
|
}
|
|
template<> uint32_t convertStringTo<uint32_t>(const std::string& _value) {
|
|
return etk::string_to_uint32_t(_value);
|
|
}
|
|
template<> uint16_t convertStringTo<uint16_t>(const std::string& _value) {
|
|
return etk::string_to_uint16_t(_value);
|
|
}
|
|
template<> uint8_t convertStringTo<uint8_t>(const std::string& _value) {
|
|
return etk::string_to_uint8_t(_value);
|
|
}
|
|
template<> std::string convertStringTo<std::string>(const std::string& _value) {
|
|
return _value;
|
|
}
|
|
template<> std::vector<std::string> convertStringTo<std::vector<std::string>>(const std::string& _value) {
|
|
std::vector<std::string> out;
|
|
JUS_TODO("Convert string to vs");
|
|
return out;
|
|
}
|
|
template<> jus::FileServer convertStringTo<jus::FileServer>(const std::string& _value) {
|
|
return jus::FileServer();
|
|
}
|
|
template<> jus::File convertStringTo<jus::File>(const std::string& _value) {
|
|
return jus::File();
|
|
}
|
|
|
|
}
|
|
|
|
ejson::Object jus::createCallJson(uint64_t _transactionId, const std::string& _functionName, ejson::Array _params) {
|
|
ejson::Object callElem = createBaseCall(_transactionId, _functionName);
|
|
callElem.add("param", _params);
|
|
return callElem;
|
|
}
|
|
|
|
ejson::Object jus::createBaseCall(uint64_t _transactionId, const std::string& _functionName, const std::string& _service) {
|
|
ejson::Object obj;
|
|
if (_service.size() != 0) {
|
|
obj.add("service", ejson::String(_service));
|
|
}
|
|
obj.add("call", ejson::String(_functionName));
|
|
obj.add("id", ejson::Number(_transactionId));
|
|
return obj;
|
|
}
|
|
void jus::createParam(ejson::Object& _obj) {
|
|
// Finish recursive parse ...
|
|
}
|
|
|
|
enum jus::AbstractFunction::type jus::AbstractFunction::getType() const {
|
|
return m_type;
|
|
}
|
|
|
|
void jus::AbstractFunction::setType(enum jus::AbstractFunction::type _type) {
|
|
m_type = _type;
|
|
}
|
|
|
|
const std::string& jus::AbstractFunction::getName() const {
|
|
return m_name;
|
|
}
|
|
|
|
const std::string& jus::AbstractFunction::getDescription() const {
|
|
return m_description;
|
|
}
|
|
|
|
void jus::AbstractFunction::setDescription(const std::string& _desc) {
|
|
m_description = _desc;
|
|
}
|
|
|
|
void jus::AbstractFunction::setParam(int32_t _idParam, const std::string& _name, const std::string& _desc) {
|
|
JUS_TODO("not implemented set param ... '" << _name << "'");
|
|
}
|
|
|
|
void jus::AbstractFunction::addParam(const std::string& _name, const std::string& _desc) {
|
|
m_paramsDescription.push_back(std::make_pair(_name, _desc));
|
|
}
|
|
|
|
void jus::AbstractFunction::setReturn(const std::string& _desc) {
|
|
m_returnDescription = _desc;
|
|
}
|
|
|
|
std::string jus::AbstractFunction::getPrototypeFull() const {
|
|
std::string out = getPrototypeReturn();
|
|
out += " ";
|
|
out += m_name;
|
|
out += "(";
|
|
std::vector<std::string> tmp = getPrototypeParam();
|
|
for (size_t iii=0; iii<tmp.size(); ++iii) {
|
|
if (iii != 0) {
|
|
out += ", ";
|
|
}
|
|
out += tmp[iii];
|
|
if (iii < m_paramsDescription.size()) {
|
|
out += " " + m_paramsDescription[iii].first;
|
|
}
|
|
}
|
|
out += ");";
|
|
return out;
|
|
}
|
|
|
|
|
|
jus::AbstractFunction::AbstractFunction(const std::string& _name,
|
|
const std::string& _desc):
|
|
m_type(jus::AbstractFunction::type::unknow),
|
|
m_name(_name),
|
|
m_description(_desc) {
|
|
|
|
}
|
|
bool jus::AbstractFunction::checkCompatibility(const ParamType& _type, const ejson::Value& _params) {
|
|
if (createType<bool>() == _type) {
|
|
return _params.isBoolean();
|
|
}
|
|
if ( createType<int64_t>() == _type
|
|
|| createType<int32_t>() == _type
|
|
|| createType<int16_t>() == _type
|
|
|| createType<int8_t>() == _type
|
|
|| createType<uint64_t>() == _type
|
|
|| createType<uint32_t>() == _type
|
|
|| createType<uint16_t>() == _type
|
|
|| createType<uint8_t>() == _type
|
|
|| createType<float>() == _type
|
|
|| createType<double>() == _type) {
|
|
return _params.isNumber();
|
|
}
|
|
if (createType<std::vector<std::string>>() == _type) {
|
|
return _params.isArray();
|
|
}
|
|
if ( createType<std::vector<bool>>() == _type
|
|
|| createType<std::vector<int64_t>>() == _type
|
|
|| createType<std::vector<int32_t>>() == _type
|
|
|| createType<std::vector<int16_t>>() == _type
|
|
|| createType<std::vector<int8_t>>() == _type
|
|
|| createType<std::vector<uint64_t>>() == _type
|
|
|| createType<std::vector<uint32_t>>() == _type
|
|
|| createType<std::vector<uint16_t>>() == _type
|
|
|| createType<std::vector<uint8_t>>() == _type
|
|
|| createType<std::vector<float>>() == _type
|
|
|| createType<std::vector<double>>() == _type) {
|
|
if (_params.isObject()) {
|
|
JUS_TODO("Special case of packaging of the data");
|
|
return false;
|
|
}
|
|
return _params.isArray();
|
|
}
|
|
if (createType<jus::File>() == _type) {
|
|
if (_params.isObject()) {
|
|
if (_params.toObject()["type"].toString().get() == "file") {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
if (createType<std::string>() == _type) {
|
|
return _params.isString();
|
|
}
|
|
return false;
|
|
}
|
|
bool jus::AbstractFunction::checkCompatibility(const ParamType& _type, const std::string& _params) {
|
|
return false;
|
|
}
|