PickupProcessTask.cpp 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  1. //
  2. // Created by zx on 2020/7/7.
  3. //
  4. #include <Parkspace_communicator.h>
  5. #include <dispatch_message.pb.h>
  6. #include "PickupProcessTask.h"
  7. #include "process_message.pb.h"
  8. #include "command_manager.h"
  9. #include "system_communicator.h"
  10. #include "uniq_key.h"
  11. PickupProcessTask::PickupProcessTask(unsigned int terminal_id)
  12. {
  13. m_terminor_id=terminal_id;
  14. message::Base_info base_info;
  15. base_info.set_msg_type(message::eStoring_process_statu_msg);
  16. base_info.set_sender(message::eMain);
  17. base_info.set_receiver(message::eEmpty);
  18. m_picking_process_statu_msg.mutable_base_info()->CopyFrom(base_info);
  19. m_picking_process_statu_msg.set_terminal_id(terminal_id);
  20. reset_process_statu();
  21. }
  22. PickupProcessTask::~PickupProcessTask()
  23. {
  24. //退出线程
  25. m_publish_exit_condition.set_pass_ever(true);
  26. if(m_publish_statu_thread!= nullptr)
  27. {
  28. if(m_publish_statu_thread->joinable())
  29. {
  30. m_publish_statu_thread->join();
  31. }
  32. delete m_publish_statu_thread;
  33. m_publish_statu_thread=nullptr;
  34. }
  35. }
  36. Error_manager PickupProcessTask::init_task(message::Command_info command_info, message::Car_info car_info)
  37. {
  38. m_command_info=command_info;
  39. m_car_info=car_info;
  40. message::Base_info base_info;
  41. base_info.set_msg_type(message::ePicking_process_statu_msg);
  42. base_info.set_sender(message::eMain);
  43. base_info.set_receiver(message::eEmpty);
  44. m_picking_process_statu_msg.mutable_base_info()->CopyFrom(base_info);
  45. reset_process_statu();
  46. ///创建状态发布线程
  47. if(m_publish_statu_thread== nullptr)
  48. {
  49. m_publish_exit_condition.reset(false, false, false);
  50. m_publish_statu_thread=new std::thread(publish_thread_func,this);
  51. }
  52. return SUCCESS;
  53. }
  54. /*
  55. * reset 进度信息
  56. */
  57. void PickupProcessTask::reset_process_statu()
  58. {
  59. message::Check_space_step_statu check_step;
  60. check_step.set_step_statu(message::eWaiting);
  61. message::Dispatch_pick_step_statu pick_step;
  62. pick_step.set_step_statu(message::eWaiting);
  63. message::Release_space_step_statu release_step;
  64. release_step.set_step_statu(message::eWaiting);
  65. message::Waitfor_leave_step_statu waitfor_leave_step;
  66. waitfor_leave_step.set_step_statu(message::eWaiting);
  67. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  68. m_picking_process_statu_msg.mutable_check_space_step()->CopyFrom(check_step);
  69. m_picking_process_statu_msg.mutable_dispatch_step()->CopyFrom(pick_step);
  70. m_picking_process_statu_msg.mutable_release_space_step()->CopyFrom(release_step);
  71. m_picking_process_statu_msg.mutable_waitfor_leave()->CopyFrom(waitfor_leave_step);
  72. m_picking_process_statu_msg.set_license(m_car_info.license());
  73. }
  74. /*
  75. * 查询车位
  76. */
  77. Error_manager PickupProcessTask::search_space()
  78. {
  79. //更新状态
  80. {
  81. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  82. m_picking_process_statu_msg.mutable_check_space_step()->set_step_statu(message::eWorking);
  83. }
  84. /*
  85. * 检验汽车信息是否正常
  86. */
  87. if(m_car_info.has_car_width()==false||m_car_info.has_car_height()== false
  88. ||m_car_info.has_license()==false)
  89. {
  90. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  91. m_picking_process_statu_msg.mutable_check_space_step()->set_step_statu(message::eError);
  92. m_picking_process_statu_msg.mutable_check_space_step()->set_description("查询车位请求汽车信息错误");
  93. return Error_manager(INVALID_MESSAGE,CRITICAL_ERROR,"查询车位请求汽车信息错误");
  94. }
  95. /*
  96. * 检查车位管理模块是否正常
  97. */
  98. Error_manager code=Parkspace_communicator::get_instance_pointer()->check_statu();
  99. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  100. if(code!=SUCCESS)
  101. {
  102. m_picking_process_statu_msg.mutable_check_space_step()->set_description(code.get_error_description());
  103. m_picking_process_statu_msg.mutable_check_space_step()->set_step_statu(message::eError);
  104. return code;
  105. }
  106. message::Base_info base_info;
  107. base_info.set_msg_type(message::eParkspace_search_request_msg);
  108. base_info.set_sender(message::eMain);
  109. base_info.set_receiver(message::eParkspace);
  110. base_info.set_timeout_ms(1000);
  111. message::Parkspace_search_request_msg request;
  112. request.mutable_command_info()->CopyFrom(m_command_info);
  113. request.mutable_command_info()->set_time(create_key());
  114. request.mutable_base_info()->CopyFrom(base_info);
  115. request.mutable_car_info()->CopyFrom(m_car_info);
  116. code = Parkspace_communicator::get_instance_pointer()->search_request(request,m_parcspace_search_response_msg);
  117. if(code==SUCCESS)
  118. {
  119. m_picking_process_statu_msg.mutable_check_space_step()->mutable_space_info()->CopyFrom(m_parcspace_search_response_msg.car_position());
  120. m_picking_process_statu_msg.mutable_check_space_step()->set_step_statu(message::eComplete);
  121. }
  122. else {
  123. m_picking_process_statu_msg.mutable_check_space_step()->set_step_statu(message::eError);
  124. m_picking_process_statu_msg.mutable_check_space_step()->set_description(code.get_error_description());
  125. }
  126. return code;
  127. }
  128. void PickupProcessTask::Main()
  129. {
  130. Error_manager code;
  131. //进入取车流程
  132. switch (0)
  133. {
  134. //第一步,执行取车动作
  135. case 0:
  136. {
  137. //更新状态
  138. {
  139. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  140. m_picking_process_statu_msg.mutable_dispatch_step()->set_step_statu(message::eWorking);
  141. m_picking_process_statu_msg.mutable_dispatch_step()->mutable_space_info()->CopyFrom(
  142. m_parcspace_search_response_msg.car_position());
  143. }
  144. //开始工作
  145. code=pickup_step();
  146. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  147. if(code!=SUCCESS)
  148. {
  149. LOG(ERROR)<<"取车调度失败,取车终端:"<<m_terminor_id<<"指令id:"<<m_command_info.place()
  150. <<", 车位id:"<<m_parcspace_search_response_msg.car_position().parkspace_id()
  151. <<", 车位楼层:"<<m_parcspace_search_response_msg.car_position().floor()
  152. <<", 车位序号:"<<m_parcspace_search_response_msg.car_position().index()
  153. <<", 车牌号:"<<m_car_info.license()
  154. <<", 库内车牌号:"<<m_parcspace_search_response_msg.car_position().car_info().license();
  155. m_picking_process_statu_msg.mutable_dispatch_step()->set_step_statu(message::eError);
  156. m_picking_process_statu_msg.mutable_dispatch_step()->set_description(code.get_error_description());
  157. break;
  158. }
  159. m_picking_process_statu_msg.mutable_dispatch_step()->set_step_statu(message::eComplete);
  160. LOG(WARNING)<<"取车调度成功,取车终端:"<<m_terminor_id<<"指令id:"<<m_command_info.place()
  161. <<", 车位id:"<<m_parcspace_search_response_msg.car_position().parkspace_id()
  162. <<", 车位楼层:"<<m_parcspace_search_response_msg.car_position().floor()
  163. <<", 车位序号:"<<m_parcspace_search_response_msg.car_position().index()
  164. <<", 车牌号:"<<m_car_info.license()
  165. <<", 库内车牌号:"<<m_parcspace_search_response_msg.car_position().car_info().license();
  166. }
  167. //第二步,清除车位
  168. case 1:
  169. {
  170. //更新状态
  171. {
  172. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  173. m_picking_process_statu_msg.mutable_release_space_step()->set_step_statu(message::eWorking);
  174. m_picking_process_statu_msg.mutable_release_space_step()->mutable_space_info()->CopyFrom(
  175. m_parcspace_search_response_msg.car_position());
  176. }
  177. code=release_space_step();
  178. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  179. if(code!=SUCCESS)
  180. {
  181. m_picking_process_statu_msg.mutable_release_space_step()->set_step_statu(message::eError);
  182. m_picking_process_statu_msg.mutable_release_space_step()->set_description(code.get_error_description());
  183. LOG(ERROR)<<"取车释放车位失败:"<<code.get_error_description();
  184. break;
  185. }
  186. m_picking_process_statu_msg.mutable_release_space_step()->set_step_statu(message::eComplete);
  187. }
  188. //第三步,等待车辆离开
  189. case 2:
  190. {
  191. //更新状态
  192. {
  193. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  194. m_picking_process_statu_msg.mutable_waitfor_leave()->set_step_statu(message::eWorking);
  195. m_picking_process_statu_msg.mutable_waitfor_leave()->mutable_car_info()->CopyFrom(m_car_info);
  196. }
  197. //等待离开
  198. code=wait_for_leave_step();
  199. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  200. if(code!=SUCCESS)
  201. {
  202. m_picking_process_statu_msg.mutable_waitfor_leave()->set_step_statu(message::eError);
  203. m_picking_process_statu_msg.mutable_waitfor_leave()->set_description(code.get_error_description());
  204. break;
  205. }
  206. m_picking_process_statu_msg.mutable_waitfor_leave()->set_step_statu(message::eComplete);
  207. }
  208. }
  209. }
  210. /*
  211. * 执行取车动作请求,并等待执行完成
  212. */
  213. Error_manager PickupProcessTask::pickup_step()
  214. {
  215. /*
  216. * 检查是否曾经分配过车位
  217. */
  218. if(m_parcspace_search_response_msg.has_car_position()==false)
  219. {
  220. return Error_manager(FAILED,MINOR_ERROR," 取车流程释放车位请求缺少车位信息");
  221. }
  222. //2,判断调度节点状态
  223. Error_manager code=Dispatch_communicator::get_instance_pointer()->check_export_statu(m_terminor_id);
  224. if(code!=SUCCESS)
  225. return code;
  226. message::Dispatch_request_msg request;
  227. message::Base_info base_info;
  228. base_info.set_msg_type(message::eDispatch_request_msg);
  229. base_info.set_sender(message::eMain);
  230. base_info.set_receiver(message::eDispatch);
  231. base_info.set_timeout_ms(1000*300); //测量超时300s
  232. request.mutable_base_info()->CopyFrom(base_info);
  233. message::Parkspace_info space_info=m_parcspace_search_response_msg.car_position();
  234. request.set_dispatch_motion_direction(message::E_PICKUP_CAR);
  235. request.set_parkspace_id(space_info.parkspace_id());
  236. request.set_terminal_id(m_terminor_id);
  237. request.mutable_command_info()->CopyFrom(m_command_info);
  238. request.mutable_command_info()->set_time(create_key());
  239. message::Dispatch_response_msg response;
  240. code=Dispatch_communicator::get_instance_pointer()->dispatch_request(request,response);
  241. if(code!=SUCCESS)
  242. return code;
  243. if(response.error_manager().error_code()==0) {
  244. return SUCCESS;
  245. }
  246. else
  247. return Error_manager(FAILED,MINOR_ERROR,"取车流程调度反馈错误码");
  248. }
  249. /*
  250. * 等待车辆离开
  251. */
  252. Error_manager PickupProcessTask::wait_for_leave_step()
  253. {
  254. return SUCCESS;
  255. }
  256. /*
  257. * 清除车位表中对应的车位
  258. */
  259. Error_manager PickupProcessTask::release_space_step()
  260. {
  261. /*
  262. * 检查是否曾经分配过车位
  263. */
  264. if(m_parcspace_search_response_msg.has_car_position()==false)
  265. {
  266. return Error_manager(FAILED,MINOR_ERROR," 取车流程释放车位请求缺少车位信息");
  267. }
  268. /*
  269. * 检查车位管理模块是否正常
  270. */
  271. Error_manager code=Parkspace_communicator::get_instance_pointer()->check_statu();
  272. if(code!=SUCCESS)
  273. return code;
  274. message::Parkspace_release_request_msg request;
  275. message::Base_info base_info;
  276. base_info.set_msg_type(message::eParkspace_release_request_msg);
  277. base_info.set_sender(message::eMain);
  278. base_info.set_receiver(message::eParkspace);
  279. base_info.set_timeout_ms(1000); //测量超时1s
  280. request.mutable_base_info()->CopyFrom(base_info);
  281. message::Parkspace_info space_info=m_parcspace_search_response_msg.car_position();
  282. request.mutable_release_space_info()->CopyFrom(space_info);
  283. request.mutable_command_info()->CopyFrom(m_command_info);
  284. request.mutable_command_info()->set_time(create_key());
  285. message::Parkspace_release_response_msg release_response;
  286. code=Parkspace_communicator::get_instance_pointer()->release_request(request,release_response);
  287. if(code!=SUCCESS)
  288. return code;
  289. if(release_response.error_manager().error_code()==0) {
  290. return SUCCESS;
  291. }
  292. else
  293. return Error_manager(FAILED,MINOR_ERROR,"取车流程parkspace release response error_code error");
  294. }
  295. /*
  296. * 发布状态线程
  297. */
  298. void PickupProcessTask::publish_thread_func(PickupProcessTask* ptask)
  299. {
  300. if(ptask)
  301. {
  302. ptask->publish_step_status();
  303. }
  304. }
  305. void PickupProcessTask::publish_step_status()
  306. {
  307. //未收到退出信号
  308. while(false==m_publish_exit_condition.wait_for_ex(std::chrono::milliseconds(50)))
  309. {
  310. /*
  311. * 通过communicator 发布状态
  312. */
  313. if(System_communicator::get_instance_pointer())
  314. {
  315. if(m_picking_process_statu_msg.has_base_info()==true)
  316. {
  317. std::lock_guard<std::mutex> lock(m_picking_statu_lock);
  318. System_communicator::get_instance_pointer()->post_entrance_statu(m_picking_process_statu_msg);
  319. }
  320. }
  321. }
  322. }