Skip to content

Commit

Permalink
python monitoring dictionary enhanced (still not complete) (eclipse-e…
Browse files Browse the repository at this point in the history
  • Loading branch information
rex-schilasky authored Aug 20, 2024
1 parent 5779c07 commit bda08a6
Showing 1 changed file with 66 additions and 1 deletion.
67 changes: 66 additions & 1 deletion lang/python/core/src/ecal_wrap.cxx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/* ========================= eCAL LICENSE =================================
*
* Copyright (C) 2016 - 2019 Continental Corporation
* Copyright (C) 2016 - 2024 Continental Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -1051,6 +1051,9 @@ namespace
val = Py_BuildValue("s", topic.hname.c_str());
PyDict_SetItemString(topicDict, "hname", val); Py_DECREF(val);

val = Py_BuildValue("s", topic.hgname.c_str());
PyDict_SetItemString(topicDict, "hgname", val); Py_DECREF(val);

val = Py_BuildValue("i", topic.pid);
PyDict_SetItemString(topicDict, "pid", val); Py_DECREF(val);

Expand All @@ -1069,14 +1072,32 @@ namespace
val = Py_BuildValue("s", topic.direction.c_str());
PyDict_SetItemString(topicDict, "direction", val); Py_DECREF(val);

// TODO: SDataTypeInformation tdatatype

// TODO: std::vector<TLayer> tlayer

val = Py_BuildValue("i", topic.tsize);
PyDict_SetItemString(topicDict, "tsize", val); Py_DECREF(val);

val = Py_BuildValue("connections_loc", topic.tsize);
PyDict_SetItemString(topicDict, "connections_loc", val); Py_DECREF(val);

val = Py_BuildValue("connections_ext", topic.tsize);
PyDict_SetItemString(topicDict, "connections_ext", val); Py_DECREF(val);

val = Py_BuildValue("message_drops", topic.tsize);
PyDict_SetItemString(topicDict, "message_drops", val); Py_DECREF(val);

val = Py_BuildValue("i", topic.did);
PyDict_SetItemString(topicDict, "did", val); Py_DECREF(val);

val = Py_BuildValue("i", topic.dclock);
PyDict_SetItemString(topicDict, "dclock", val); Py_DECREF(val);

val = Py_BuildValue("i", topic.dfreq);
PyDict_SetItemString(topicDict, "dfreq", val); Py_DECREF(val);

// TODO: std::map<std::string, std::string> attr
}
}
}
Expand Down Expand Up @@ -1106,6 +1127,9 @@ PyObject* mon_monitoring(PyObject* /*self*/, PyObject* /*args*/)
val = Py_BuildValue("s", process.hname.c_str());
PyDict_SetItemString(processDict, "hname", val); Py_DECREF(val);

val = Py_BuildValue("s", process.hgname.c_str());
PyDict_SetItemString(processDict, "hgname", val); Py_DECREF(val);

val = Py_BuildValue("i", process.pid);
PyDict_SetItemString(processDict, "pid", val); Py_DECREF(val);

Expand Down Expand Up @@ -1138,6 +1162,9 @@ PyObject* mon_monitoring(PyObject* /*self*/, PyObject* /*args*/)

val = Py_BuildValue("s", process.component_init_info.c_str());
PyDict_SetItemString(processDict, "component_init_info", val); Py_DECREF(val);

val = Py_BuildValue("s", process.ecal_runtime_version.c_str());
PyDict_SetItemString(processDict, "ecal_runtime_version", val); Py_DECREF(val);
}
}

Expand Down Expand Up @@ -1172,6 +1199,15 @@ PyObject* mon_monitoring(PyObject* /*self*/, PyObject* /*args*/)
val = Py_BuildValue("s", service.sid.c_str());
PyDict_SetItemString(serviceDict, "sid", val); Py_DECREF(val);

val = Py_BuildValue("i", service.version);
PyDict_SetItemString(serviceDict, "version", val); Py_DECREF(val);

val = Py_BuildValue("i", service.tcp_port_v0);
PyDict_SetItemString(serviceDict, "tcp_port_v0", val); Py_DECREF(val);

val = Py_BuildValue("i", service.tcp_port_v1);
PyDict_SetItemString(serviceDict, "tcp_port_v1", val); Py_DECREF(val);

PyObject* methodsDict = PyDict_New();
PyDict_SetItemString(serviceDict, "methods", methodsDict); Py_DECREF(methodsDict);

Expand All @@ -1183,9 +1219,13 @@ PyObject* mon_monitoring(PyObject* /*self*/, PyObject* /*args*/)
val = Py_BuildValue("s", method.req_type.c_str());
PyDict_SetItemString(methodsDict, "req_type", val); Py_DECREF(val);

// TODO: std::string req_desc

val = Py_BuildValue("s", method.resp_type.c_str());
PyDict_SetItemString(methodsDict, "resp_type", val); Py_DECREF(val);

// TODO: std::string resp_desc

val = Py_BuildValue("i", method.call_count);
PyDict_SetItemString(methodsDict, "call_count", val); Py_DECREF(val);
}
Expand Down Expand Up @@ -1222,6 +1262,31 @@ PyObject* mon_monitoring(PyObject* /*self*/, PyObject* /*args*/)

val = Py_BuildValue("s", client.sid.c_str());
PyDict_SetItemString(clientDict, "sid", val); Py_DECREF(val);

PyObject* methodsDict = PyDict_New();
PyDict_SetItemString(clientDict, "methods", methodsDict); Py_DECREF(methodsDict);

for (const auto method : client.methods)
{
val = Py_BuildValue("s", method.mname.c_str());
PyDict_SetItemString(methodsDict, "mname", val); Py_DECREF(val);

val = Py_BuildValue("s", method.req_type.c_str());
PyDict_SetItemString(methodsDict, "req_type", val); Py_DECREF(val);

// TODO: std::string req_desc

val = Py_BuildValue("s", method.resp_type.c_str());
PyDict_SetItemString(methodsDict, "resp_type", val); Py_DECREF(val);

// TODO: std::string resp_desc

val = Py_BuildValue("i", method.call_count);
PyDict_SetItemString(methodsDict, "call_count", val); Py_DECREF(val);
}

val = Py_BuildValue("i", client.version);
PyDict_SetItemString(clientDict, "version", val); Py_DECREF(val);
}
}

Expand Down

0 comments on commit bda08a6

Please sign in to comment.