dispatch_process.cpp 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. //
  2. // Created by huli on 2021/3/22.
  3. //
  4. #include "dispatch_process.h"
  5. #include "../system/system_communication.h"
  6. #include "../dispatch/dispatch_manager.h"
  7. Dispatch_process::Dispatch_process()
  8. {
  9. m_dispatch_process_status = DISPATCH_PROCESS_STATUS_UNKNOW;
  10. m_dispatch_process_type = DISPATCH_PROCESS_TYPE_UNKNOW;
  11. m_dispatch_source = 0;
  12. m_dispatch_destination = 0;
  13. }
  14. Dispatch_process::~Dispatch_process()
  15. {
  16. Dispatch_process_uninit();
  17. }
  18. //初始化, 就把主控发送的请求传入即可.
  19. Error_manager Dispatch_process::Dispatch_process_init(message::Dispatch_request_msg dispatch_request_msg)
  20. {
  21. if ( dispatch_request_msg.base_info().has_timeout_ms() )
  22. {
  23. m_timeout_ms = dispatch_request_msg.base_info().timeout_ms() - DISPATCH_PROCESS_ATTENUATION_TIMEOUT_MS;
  24. }
  25. else
  26. {
  27. m_timeout_ms = DISPATCH_PROCESS_TIMEOUT_MS - DISPATCH_PROCESS_ATTENUATION_TIMEOUT_MS;
  28. }
  29. m_command_key = dispatch_request_msg.command_key();
  30. m_start_time = std::chrono::system_clock::now();
  31. if ( dispatch_request_msg.dispatch_motion_direction() == message::E_STORE_CAR )
  32. {
  33. m_dispatch_process_type = DISPATCH_PROCESS_STORE;
  34. m_dispatch_source = dispatch_request_msg.terminal_id() + PASSAGEWAY_ID_BASE ;
  35. m_dispatch_destination = dispatch_request_msg.parkspace_info().parkspace_id() + PARKSPACE_ID_BASE;
  36. Common_data::copy_data(m_parkspace_information, dispatch_request_msg.parkspace_info());
  37. Common_data::copy_data(m_car_measure_information, dispatch_request_msg.locate_information());
  38. }
  39. else if( dispatch_request_msg.dispatch_motion_direction() == message::E_PICKUP_CAR )
  40. {
  41. m_dispatch_process_type = DISPATCH_PROCESS_PICKUP;
  42. m_dispatch_source = dispatch_request_msg.parkspace_info().parkspace_id() + PARKSPACE_ID_BASE;
  43. m_dispatch_destination = dispatch_request_msg.terminal_id() + PASSAGEWAY_ID_BASE ;
  44. Common_data::copy_data(m_parkspace_information, dispatch_request_msg.parkspace_info());
  45. }
  46. else
  47. {
  48. m_dispatch_process_type = DISPATCH_PROCESS_TYPE_UNKNOW;
  49. return Error_manager(Error_code::PARAMETER_ERROR, Error_level::MINOR_ERROR,
  50. " Dispatch_process::Dispatch_process_init ERROR ");
  51. }
  52. m_dispatch_process_status = DISPATCH_PROCESS_CREATED;
  53. return Error_code::SUCCESS;
  54. }
  55. //反初始化
  56. Error_manager Dispatch_process::Dispatch_process_uninit()
  57. {
  58. return Error_code::SUCCESS;
  59. }
  60. void Dispatch_process::Main()
  61. {
  62. Error_manager t_error;
  63. //主流程, 循环执行
  64. while ( std::chrono::system_clock::now() - m_start_time < std::chrono::milliseconds(m_timeout_ms) )
  65. {
  66. std::this_thread::sleep_for(std::chrono::microseconds(1));
  67. switch ( m_dispatch_process_status )
  68. {
  69. case DISPATCH_PROCESS_CREATED:
  70. {
  71. //检查调度请求
  72. m_result = check_dispatch_request_msg();
  73. if ( m_result !=Error_code::SUCCESS)
  74. {
  75. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  76. break;
  77. }
  78. //发送调度总计划
  79. m_result = send_dispatch_plan_request_msg();
  80. if ( m_result !=Error_code::SUCCESS)
  81. {
  82. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  83. break;
  84. }
  85. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  86. m_dispatch_process_status = DISPATCH_PROCESS_READY;
  87. break;
  88. }
  89. case DISPATCH_PROCESS_READY:
  90. {
  91. //等待控制指令
  92. m_result = wait_dispatch_control_request_msg();
  93. if ( m_result !=Error_code::SUCCESS)
  94. {
  95. //不成功, 就表示没有新的指令, 那么什么都不做, 原地待命
  96. }
  97. else
  98. {
  99. //流程正常, 就进入工作状态,
  100. m_dispatch_process_status = DISPATCH_PROCESS_WORKING;
  101. break;
  102. }
  103. //等待调度总计划答复
  104. m_result = wait_dispatch_plan_response_msg();
  105. if ( m_result !=Error_code::SUCCESS)
  106. {
  107. //不成功, 就表示没有总计划答复, 那么什么都不做, 原地待命
  108. }
  109. else
  110. {
  111. //流程正常, 就进入完成状态,
  112. m_dispatch_process_status = DISPATCH_PROCESS_OVER;
  113. break;
  114. }
  115. break;
  116. }
  117. case DISPATCH_PROCESS_WORKING:
  118. {
  119. break;
  120. }
  121. case DISPATCH_PROCESS_OVER:
  122. {
  123. //发送调度答复, 发给主控的
  124. m_result = send_dispatch_response_msg();
  125. if ( m_result !=Error_code::SUCCESS)
  126. {
  127. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  128. break;
  129. }
  130. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  131. m_dispatch_process_status = DISPATCH_PROCESS_RELEASE;
  132. break;
  133. }
  134. case DISPATCH_PROCESS_RELEASE:
  135. {
  136. //通知调度管理, 释放资源,
  137. m_result = release_resource();
  138. if ( m_result !=Error_code::SUCCESS)
  139. {
  140. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  141. break;
  142. }
  143. //在这里, 整个流程彻底结束, 之后线程池会自动回收 这个流程对象的资源
  144. return;
  145. break;
  146. }
  147. case DISPATCH_PROCESS_FAULT:
  148. {
  149. break;
  150. }
  151. default:
  152. {
  153. break;
  154. }
  155. }
  156. }
  157. //任务超时
  158. return;
  159. }
  160. //检查调度请求
  161. Error_manager Dispatch_process::check_dispatch_request_msg()
  162. {
  163. std::unique_lock<std::mutex> t_lock(m_lock);
  164. return Error_code::SUCCESS;
  165. }
  166. //发送调度总计划
  167. Error_manager Dispatch_process::send_dispatch_plan_request_msg()
  168. {
  169. std::unique_lock<std::mutex> t_lock(m_lock);
  170. m_dispatch_plan_request_msg.mutable_base_info()->set_msg_type(message::Message_type::eDispatch_plan_request_msg);
  171. m_dispatch_plan_request_msg.mutable_base_info()->set_timeout_ms(m_timeout_ms);
  172. m_dispatch_plan_request_msg.mutable_base_info()->set_sender(message::Communicator::eDispatch_mamager);
  173. m_dispatch_plan_request_msg.mutable_base_info()->set_receiver(message::Communicator::eDispatch_control);
  174. m_dispatch_plan_request_msg.set_command_key(m_command_key);
  175. m_dispatch_plan_request_msg.set_dispatch_task_type((message::Dispatch_task_type)m_dispatch_process_type);
  176. m_dispatch_plan_request_msg.set_dispatch_source(m_dispatch_source);
  177. m_dispatch_plan_request_msg.set_dispatch_destination(m_dispatch_destination);
  178. //这里不写错误码
  179. std::string t_msg = m_dispatch_plan_request_msg.SerializeAsString();
  180. System_communication::get_instance_references().encapsulate_msg(t_msg);
  181. return Error_code::SUCCESS;
  182. }
  183. //等待控制指令
  184. Error_manager Dispatch_process::wait_dispatch_control_request_msg()
  185. {
  186. std::unique_lock<std::mutex> t_lock(m_lock);
  187. //key不相等 就表示 收到了新的控制指令
  188. if ( m_dispatch_control_request_msg.command_key() == m_dispatch_control_response_msg.command_key() )
  189. {
  190. return Error_code::NODATA;
  191. }
  192. else
  193. {
  194. return Error_code::SUCCESS;
  195. }
  196. }
  197. //执行调度控制指令, 并根据完成情况给答复
  198. Error_manager Dispatch_process::excute_dispatch_control()
  199. {
  200. std::unique_lock<std::mutex> t_lock(m_lock);
  201. return Error_code::SUCCESS;
  202. }
  203. //等待调度总计划答复
  204. Error_manager Dispatch_process::wait_dispatch_plan_response_msg()
  205. {
  206. std::unique_lock<std::mutex> t_lock(m_lock);
  207. //key 相等 就表示 收到了总计划答复
  208. if ( m_dispatch_plan_request_msg.command_key() == m_dispatch_plan_response_msg.command_key() )
  209. {
  210. return Error_code::SUCCESS;
  211. }
  212. else
  213. {
  214. return Error_code::NODATA;
  215. }
  216. }
  217. //发送调度答复, 发给主控的
  218. Error_manager Dispatch_process::send_dispatch_response_msg()
  219. {
  220. std::unique_lock<std::mutex> t_lock(m_lock);
  221. m_dispatch_response_msg.mutable_base_info()->set_msg_type(message::Message_type::eDispatch_response_msg);
  222. m_dispatch_response_msg.mutable_base_info()->set_timeout_ms(m_timeout_ms);
  223. m_dispatch_response_msg.mutable_base_info()->set_sender(message::Communicator::eDispatch_mamager);
  224. m_dispatch_response_msg.mutable_base_info()->set_receiver(message::Communicator::eMain);
  225. m_dispatch_response_msg.set_command_key(m_command_key);
  226. m_dispatch_response_msg.mutable_error_manager()->CopyFrom(m_dispatch_plan_response_msg.error_manager());
  227. std::string t_msg = m_dispatch_response_msg.SerializeAsString();
  228. System_communication::get_instance_references().encapsulate_msg(t_msg);
  229. return Error_code::SUCCESS;
  230. }
  231. //通知调度管理, 释放资源,
  232. Error_manager Dispatch_process::release_resource()
  233. {
  234. return Dispatch_manager::get_instance_references().release_dispatch_process(m_command_key);
  235. }