1 Star 0 Fork 3

jinzhu6/agv_dispatch

forked from ros-org/agv_dispatch 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
msgprocess.cpp 24.97 KB
一键复制 编辑 原始数据 按行查看 历史
qintxwd 提交于 2018-11-28 14:38 . 任务取消后不再从界面消失
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597
#include "msgprocess.h"
#include "network/session.h"
#include "network/sessionmanager.h"
#include "usermanager.h"
#include "mapmap/mapmanager.h"
#include "agvmanager.h"
#include "userlogmanager.h"
#include "taskmanager.h"
#include "common.h"
#include "device/devicemanager.h"
#include "device/new_elevator/newelevatormanager.h"
MsgProcess::MsgProcess()
{
}
void MsgProcess::interAddSubAgvPosition(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " sub AGV position info");
addSubAgvPosition(conn);
conn->send(response);
}
void MsgProcess::interAddSubAgvStatus(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " sub AGV status info");
addSubAgvStatus(conn);
conn->send(response);
}
void MsgProcess::interAddSubTask(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " sub task info");
addSubTask(conn);
conn->send(response);
}
void MsgProcess::interAddSubLog(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " sub log info");
addSubLog(conn);
conn->send(response);
}
void MsgProcess::interAddSubELE(ClientSessionPtr conn, const Json::Value &request)
{
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " sub ele info");
addSubELE(conn);
conn->send(response);
}
void MsgProcess::interRemoveSubAgvPosition(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " cancel AGV position info");
removeSubAgvPosition(conn);
conn->send(response);
}
void MsgProcess::interRemoveSubAgvStatus(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " cancel AGV status info");
removeSubAgvStatus(conn);
conn->send(response);
}
void MsgProcess::interRemoveSubTask(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " cancel task info");
removeSubTask(conn);
conn->send(response);
}
void MsgProcess::interRemoveSubLog(ClientSessionPtr conn, const Json::Value &request) {
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " cancel sub log");
removeSubLog(conn);
conn->send(response);
}
void MsgProcess::interRemoveSubELE(ClientSessionPtr conn, const Json::Value &request)
{
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_SUCCESS;
UserLogManager::getInstance()->push(conn->getUserName() + " cancel sub ele");
removeSubELE(conn);
conn->send(response);
}
void MsgProcess::onSessionClosed(ClientSessionPtr id)
{
removeSubAgvPosition(id);
removeSubAgvStatus(id);
removeSubTask(id);
removeSubLog(id);
removeSubELE(id);
}
void MsgProcess::addSubAgvPosition(ClientSessionPtr id)
{
UNIQUE_LCK(psMtx);
if (std::find(agvPositionSubers.begin(), agvPositionSubers.end(), id) == agvPositionSubers.end()) {
agvPositionSubers.push_back(id);
}
}
void MsgProcess::addSubAgvStatus(ClientSessionPtr id)
{
UNIQUE_LCK(ssMtx);
if (std::find(agvStatusSubers.begin(), agvStatusSubers.end(), id) == agvStatusSubers.end()) {
agvStatusSubers.push_back(id);
}
}
void MsgProcess::addSubTask(ClientSessionPtr id)
{
UNIQUE_LCK(tsMtx);
if (std::find(taskSubers.begin(), taskSubers.end(), id) == taskSubers.end()) {
taskSubers.push_back(id);
}
}
void MsgProcess::addSubLog(ClientSessionPtr id)
{
UNIQUE_LCK(lsMtx);
if (std::find(logSubers.begin(), logSubers.end(), id) == logSubers.end()) {
logSubers.push_back(id);
}
}
void MsgProcess::addSubELE(ClientSessionPtr id)
{
UNIQUE_LCK(eleMtx);
if (std::find(eleSubers.begin(), eleSubers.end(), id) == eleSubers.end()) {
eleSubers.push_back(id);
}
}
void MsgProcess::removeSubAgvPosition(ClientSessionPtr id)
{
UNIQUE_LCK(psMtx);
auto itr = std::find(agvPositionSubers.begin(), agvPositionSubers.end(), id);
if (itr != agvPositionSubers.end()) {
agvPositionSubers.erase(itr);
}
}
void MsgProcess::removeSubAgvStatus(ClientSessionPtr id)
{
UNIQUE_LCK(ssMtx);
auto itr = std::find(agvStatusSubers.begin(), agvStatusSubers.end(), id);
if (itr != agvStatusSubers.end()) {
agvStatusSubers.erase(itr);
}
}
void MsgProcess::removeSubTask(ClientSessionPtr id)
{
UNIQUE_LCK(tsMtx);
auto itr = std::find(taskSubers.begin(), taskSubers.end(), id);
if (itr != taskSubers.end()) {
taskSubers.erase(itr);
}
}
void MsgProcess::removeSubLog(ClientSessionPtr id)
{
UNIQUE_LCK(lsMtx);
auto itr = std::find(logSubers.begin(), logSubers.end(), id);
if (itr != logSubers.end()) {
logSubers.erase(itr);
}
}
void MsgProcess::removeSubELE(ClientSessionPtr id)
{
UNIQUE_LCK(eleMtx);
auto itr = std::find(eleSubers.begin(), eleSubers.end(), id);
if (itr != eleSubers.end()) {
eleSubers.erase(itr);
}
}
//100ms一次,发布AGV的位置
void MsgProcess::publisher_agv_position()
{
const int position_pub_interval = 200;//100ms
std::chrono::high_resolution_clock::time_point beginTime = std::chrono::high_resolution_clock::now();
while (!g_quit)
{
std::this_thread::sleep_for(std::chrono::milliseconds(20));
std::chrono::high_resolution_clock::time_point endTime = std::chrono::high_resolution_clock::now();
std::chrono::milliseconds interval = std::chrono::duration_cast<std::chrono::milliseconds>(endTime - beginTime);
if (interval.count() >= position_pub_interval) {
beginTime = endTime;
//获取位置信息
Json::Value aps;
aps["type"] = MSG_TYPE_PUBLISH;
aps["todo"] = MSG_TODO_PUB_AGV_POSITION;
aps["queuenumber"] = 0;
//AgvManager::getInstance()->getPositionJson(aps);
UNIQUE_LCK(psMtx);
if (agvPositionSubers.empty())continue;
AgvManager::getInstance()->getPositionJson(aps);
if (aps["agvs"].isNull())continue;
//执行发送
for(auto itr = agvPositionSubers.begin();itr!=agvPositionSubers.end();++itr){
(*itr)->send(aps);
}
}
}
}
//每200ms发布一次小车状态
void MsgProcess::publisher_agv_status()
{
const int status_pub_interval = 1000;//200ms
std::chrono::high_resolution_clock::time_point beginTime = std::chrono::high_resolution_clock::now();
auto agvmanagerptr = AgvManager::getInstance();
while (!g_quit)
{
std::this_thread::sleep_for(std::chrono::milliseconds(10));
std::chrono::high_resolution_clock::time_point endTime = std::chrono::high_resolution_clock::now();
std::chrono::milliseconds interval = std::chrono::duration_cast<std::chrono::milliseconds>(endTime - beginTime);
if (interval.count() >= status_pub_interval) {
beginTime = endTime;
//组装信息
Json::Value response;
response["type"] = MSG_TYPE_PUBLISH;
response["todo"] = MSG_TODO_PUB_AGV_STATUS;
response["queuenumber"] = 0;
agvmanagerptr->getStatusJson(response);
//TODO
UNIQUE_LCK(ssMtx);
if (agvStatusSubers.empty())continue;
//执行发送
for(auto itr = agvStatusSubers.begin();itr!=agvStatusSubers.end();++itr){
(*itr)->send(response);
}
}
}
}
//每500ms发布一次 当前任务的状态
void MsgProcess::publisher_task()
{
const int task_pub_interval = 1000;//500ms
std::chrono::high_resolution_clock::time_point beginTime = std::chrono::high_resolution_clock::now();
while (!g_quit)
{
std::this_thread::sleep_for(std::chrono::milliseconds(50));
std::chrono::high_resolution_clock::time_point endTime = std::chrono::high_resolution_clock::now();
std::chrono::milliseconds interval = std::chrono::duration_cast<std::chrono::milliseconds>(endTime - beginTime);
if (interval.count() >= task_pub_interval) {
beginTime = endTime;
//组装信息
Json::Value response;
response["type"] = MSG_TYPE_PUBLISH;
response["todo"] = MSG_TODO_PUB_TASK;
response["queuenumber"] = 0;
auto tasks = TaskManager::getInstance()->getCurrentTasks();
//if (tasks.size() <= 0)continue;
Json::Value v_tasks;
for (auto task : tasks) {
Json::Value v_task;
v_task["id"] = task->getId();
v_task["agv"] = task->getAgv();
v_task["priority"] = task->getPriority();
v_task["status"] = task->getStatus();
v_task["produceTime"] = task->getProduceTime();
v_task["doTime"] = task->getDoTime();
v_task["doneTime"] = task->getDoneTime();
v_task["cancelTime"] = task->getCancelTime();
v_task["doingIndex"] = task->getDoingIndex();
v_task["errorCode"] = task->getErrorCode();
v_task["errorInfo"] = task->getErrorInfo();
v_task["errorTime"] = task->getErrorTime();
v_task["isCancel"] = task->getIsCancel();
v_task["describe"] = task->getDescribe();
Json::Value v_extraParams;
auto params = task->getExtraParams();
for (auto param : params) {
v_extraParams[param.first] = param.second;
}
if (!v_extraParams.isNull()) {
v_task["extraParams"] = v_extraParams;
}
auto nodes = task->getTaskNodes();
Json::Value v_nodes;
for (auto node : nodes) {
Json::Value v_node;
auto things = node->getDoThings();
Json::Value v_things;
for (auto thing : things) {
Json::Value v_thing;
v_thing["id"] = thing->type() - AgvTaskNodeDoThing::Type;
v_thing["name"] = thing->discribe();
Json::Value v_params;
auto pparams = thing->getParams();
int kk = 0;
for (auto pparam : pparams) {
v_params[kk] = pparam;
}
if (!v_params.isNull())
v_thing["params"] = v_params;
v_things.append(v_thing);
}
v_node["station"] = node->getStation();
v_node["things"] = v_things;
v_nodes.append(v_node);
}
v_task["nodes"] = v_nodes;
v_tasks.append(v_task);
}
response["tasks"] = v_tasks;
//执行发送
UNIQUE_LCK(tsMtx);
if (taskSubers.size() <= 0)continue;
for(auto itr = taskSubers.begin();itr!=taskSubers.end();++itr){
(*itr)->send(response);
}
}
}
}
void MsgProcess::publisher_ELE()
{
const int task_pub_interval = 2000;//2000ms
auto elemanagerptr = NewElevatorManager::getInstance();
std::chrono::high_resolution_clock::time_point beginTime = std::chrono::high_resolution_clock::now();
while (!g_quit)
{
std::this_thread::sleep_for(std::chrono::milliseconds(50));
std::chrono::high_resolution_clock::time_point endTime = std::chrono::high_resolution_clock::now();
std::chrono::milliseconds interval = std::chrono::duration_cast<std::chrono::milliseconds>(endTime - beginTime);
if (interval.count() >= task_pub_interval) {
beginTime = endTime;
//组装信息
Json::Value response;
response["type"] = MSG_TYPE_PUBLISH;
response["todo"] = MSG_TODO_PUB_ELE;
response["queuenumber"] = 0;
Json::Value v_eles;
auto eles = elemanagerptr->getAllEles();
for (auto ele : eles) {
if (ele == nullptr)continue;
Json::Value v_ele;
v_ele["id"] = ele->getId();
v_ele["connect"] = ele->getIsConnected();
v_ele["enable"] = ele->getIsEnabled();
v_eles.append(v_ele);
}
response["eles"] = v_eles;
UNIQUE_LCK(eleMtx);
if (eleSubers.size() <= 0)continue;
for(auto itr = eleSubers.begin();itr!=eleSubers.end();++itr){
(*itr)->send(response);
}
}
}
}
bool MsgProcess::init()
{
//启动3个pulish的线程
g_threads.create_thread(std::bind(&MsgProcess::publisher_agv_position, this));
g_threads.create_thread(std::bind(&MsgProcess::publisher_agv_status, this));
g_threads.create_thread(std::bind(&MsgProcess::publisher_task, this));
g_threads.create_thread(std::bind(&MsgProcess::publisher_ELE, this));
//日志发布时每次产生一个日志,发布一个日志
return true;
}
void MsgProcess::sessionLogout(int user_id)
{
//设置用户登录状态为
std::stringstream ss;
ss << "update agv_user set user_status=1 where id= " << user_id;
g_db.execDML(ss.str().c_str());
}
//进来一个消息,分配给一个线程去处理它
void MsgProcess::processOneMsg(const Json::Value &request, ClientSessionPtr session)
{
//request需要copy一个到线程中。
g_threads.create_thread([&, request, session] {
// TimeUsed t;
// t.start();
//处理消息,如果有返回值,发送返回值
if ((session->getUserId() <= 0 || session->getUserRole() <= USER_ROLE_VISITOR)) {
if (request["todo"].asInt() != MSG_TODO_USER_LOGIN) {
//未登录,却发送了 登录以外的 其它请求
Json::Value response;
response["type"] = MSG_TYPE_RESPONSE;
response["todo"] = request["todo"];
response["queuenumber"] = request["queuenumber"];
response["result"] = RETURN_MSG_RESULT_FAIL;
response["error_code"] = RETURN_MSG_ERROR_CODE_NOT_LOGIN;
session->send(response);
return;
}
}
typedef std::function<void(ClientSessionPtr, const Json::Value &)> ProcessFunction;
//TODO:
//combined_logger->debug("recv request:{0}", request.toStyledString());
UserManagerPtr userManager = UserManager::getInstance();
MapManagerPtr mapManager = MapManager::getInstance();
AgvManagerPtr agvManager = AgvManager::getInstance();
DeviceManagerPtr deviceManager = DeviceManager::getInstance();
NewElevatorManagerPtr elemanagerptr = NewElevatorManager::getInstance();
MsgProcessPtr msgProcess = shared_from_this();
UserLogManagerPtr userLogManager = UserLogManager::getInstance();
TaskManagerPtr taskManager = TaskManager::getInstance();
static struct
{
MSG_TODO t;
ProcessFunction f;
} table[] =
{
{ MSG_TODO_USER_LOGIN,std::bind(&UserManager::interLogin,userManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_USER_LOGOUT,std::bind(&UserManager::interLogout,userManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_USER_CHANGED_PASSWORD,std::bind(&UserManager::interChangePassword,userManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_USER_LIST,std::bind(&UserManager::interList,userManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_USER_DELTE,std::bind(&UserManager::interRemove,userManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_USER_ADD,std::bind(&UserManager::interAdd,userManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_USER_MODIFY,std::bind(&UserManager::interModify,userManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_MAP_SET_MAP,std::bind(&MapManager::interSetMap,mapManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_MAP_GET_MAP,std::bind(&MapManager::interGetMap,mapManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_AGV_MANAGE_LIST,std::bind(&AgvManager::interList,agvManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_AGV_MANAGE_ADD,std::bind(&AgvManager::interAdd,agvManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_AGV_MANAGE_DELETE,std::bind(&AgvManager::interDelete,agvManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_AGV_MANAGE_MODIFY,std::bind(&AgvManager::interModify,agvManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TASK_CREATE,std::bind(&TaskManager::interCreate,taskManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TASK_QUERY_STATUS,std::bind(&TaskManager::interQueryStatus,taskManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TASK_CANCEL,std::bind(&TaskManager::interCancel,taskManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TASK_LIST_UNDO,std::bind(&TaskManager::interListUndo,taskManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TASK_LIST_DOING,std::bind(&TaskManager::interListDoing,taskManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TASK_LIST_DONE_TODAY,std::bind(&TaskManager::interListDoneToday,taskManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TASK_LIST_DURING,std::bind(&TaskManager::interListDuring,taskManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_LOG_LIST_DURING,std::bind(&UserLogManager::interLogDuring,userLogManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_SUB_AGV_POSITION,std::bind(&MsgProcess::interAddSubAgvPosition,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_CANCEL_SUB_AGV_POSITION,std::bind(&MsgProcess::interRemoveSubAgvPosition,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_SUB_AGV_STATSU,std::bind(&MsgProcess::interAddSubAgvStatus,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_CANCEL_SUB_AGV_STATSU,std::bind(&MsgProcess::interRemoveSubAgvStatus,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_SUB_LOG,std::bind(&MsgProcess::interAddSubLog,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_CANCEL_SUB_LOG,std::bind(&MsgProcess::interRemoveSubLog,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_SUB_TASK,std::bind(&MsgProcess::interAddSubTask,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_CANCEL_SUB_TASK,std::bind(&MsgProcess::interRemoveSubTask,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TRAFFIC_CONTROL_STATION,std::bind(&MapManager::interTrafficControlStation,mapManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TRAFFIC_CONTROL_LINE,std::bind(&MapManager::interTrafficControlLine,mapManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TRAFFIC_RELEASE_STATION,std::bind(&MapManager::interTrafficReleaseStation,mapManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_TRAFFIC_RELEASE_LINE,std::bind(&MapManager::interTrafficReleaseLine,mapManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_AGV_MANAGE_STOP,std::bind(&AgvManager::interStop,agvManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_QUERY_DEVICE_LOG,std::bind(&DeviceManager::getDeviceLog,deviceManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_ELEVATOR_CONTROL,std::bind(&DeviceManager::interElevatorControl,deviceManager,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_SUB_ELE_STATSU,std::bind(&MsgProcess::interAddSubELE,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_CANCEL_SUB_ELE_STATSU,std::bind(&MsgProcess::interRemoveSubELE,msgProcess,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_ELE_ENABLE,std::bind(&NewElevatorManager::interSetEnableELE,elemanagerptr,std::placeholders::_1,std::placeholders::_2) },
{ MSG_TODO_AGV_INIT_POSITION,std::bind(&AgvManager::interInitPosition,agvManager,std::placeholders::_1,std::placeholders::_2) }
};
table[request["todo"].asInt()].f(session, request);
// t.end();
// combined_logger->debug("msg process time used:{0} ms",t.getUsed()*1000.0);
});
}
void MsgProcess::publishOneLog(USER_LOG log)
{
//异步发布
g_threads.create_thread([&, log] {
if (logSubers.empty())return;
Json::Value response;
response["type"] = MSG_TYPE_PUBLISH;
response["todo"] = MSG_TODO_PUB_LOG;
response["queuenumber"] = 0;
Json::Value vlog;
vlog["time"] = log.time;
vlog["msg"] = log.msg;
response["log"] = vlog;
UNIQUE_LCK(lsMtx);
for(auto itr = logSubers.begin();itr!=logSubers.end();++itr){
(*itr)->send(response);
}
});
}
void MsgProcess::errorOccur(int code, std::string msg, bool needConfirm)
{
errorMtx.lock();
error_code = code;
error_info = msg;
needConfirm = needConfirm;
errorMtx.unlock();
notifyAll(ENUM_NOTIFY_ALL_TYPE_ERROR);
}
void MsgProcess::notifyAll(ENUM_NOTIFY_ALL_TYPE type)
{
if (type == ENUM_NOTIFY_ALL_TYPE_MAP_UPDATE) {
Json::Value response;
response["type"] = MSG_TYPE_NOTIFY;
response["todo"] = MSG_TODO_NOTIFY_ALL_MAP_UPDATE;
response["queuenumber"] = 0;
SessionManager::getInstance()->sendToAllClient(response);
}
else if (type == ENUM_NOTIFY_ALL_TYPE_ERROR) {
Json::Value response;
response["type"] = MSG_TYPE_NOTIFY;
response["todo"] = MSG_TODO_NOTIFY_ALL_ERROR;
response["queuenumber"] = 0;
response["needConfirm"] = needConfirm;
response["error_code"] = error_code;
response["error_info"] = error_info;
SessionManager::getInstance()->sendToAllClient(response);
}
else if (type == ENUM_NOTIFY_INIT_POSITION_OK) {
needConfirm = true;
Json::Value response;
response["type"] = MSG_TYPE_NOTIFY;
response["todo"] = ENUM_NOTIFY_INIT_POSITION_OK;
response["queuenumber"] = 0;
response["needConfirm"] = needConfirm;
response["error_code"] = "";
response["error_info"] = "";
SessionManager::getInstance()->sendToAllClient(response);
}
else if (type == ENUM_NOTIFY_INIT_POSITION_FAIL) {
Json::Value response;
response["type"] = MSG_TYPE_NOTIFY;
response["todo"] = ENUM_NOTIFY_INIT_POSITION_FAIL;
response["queuenumber"] = 0;
response["needConfirm"] = needConfirm;
response["error_code"] = "";
response["error_info"] = "";
SessionManager::getInstance()->sendToAllClient(response);
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/jinzhu6/agv_dispatch.git
git@gitee.com:jinzhu6/agv_dispatch.git
jinzhu6
agv_dispatch
agv_dispatch
master

搜索帮助