system_communication.cpp 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. //
  2. // Created by huli on 2020/6/28.
  3. //
  4. #include "system_communication.h"
  5. //#include "../laser/laser_manager.h"
  6. //#include "../locate/locate_manager.h"
  7. #include "../system/system_executor.h"
  8. System_communication::System_communication()
  9. {
  10. }
  11. System_communication::~System_communication()
  12. {
  13. }
  14. //检查消息是否有效, 主要检查消息类型和接受者, 判断这条消息是不是给我的.
  15. Error_manager System_communication::check_msg(Communication_message* p_msg)
  16. {
  17. return System_executor::get_instance_references().check_msg(p_msg);
  18. }
  19. //检查执行者的状态, 判断能否处理这条消息, 需要子类重载
  20. Error_manager System_communication::check_executer(Communication_message* p_msg)
  21. {
  22. //检查对应模块的状态, 判断是否可以处理这条消息
  23. //同时也要判断是否超时, 超时返回 COMMUNICATION_ANALYSIS_TIME_OUT
  24. //如果处理器正在忙别的, 那么返回 COMMUNICATION_EXCUTER_IS_BUSY
  25. // std::cout << "Communication_socket_base::check_msg p_buf = " << p_msg->get_message_buf() << std::endl;
  26. // std::cout << "Communication_socket_base::check_msg size = " << p_msg->get_message_buf().size() << std::endl;
  27. Error_manager t_error;
  28. if ( p_msg->is_over_time() )
  29. {
  30. std::cout << "COMMUNICATION_ANALYSIS_TIME_OUT , " << std::endl;
  31. //超时:接收方不做处理,发送方会进行超时处理
  32. return Error_code::COMMUNICATION_ANALYSIS_TIME_OUT;
  33. }
  34. else
  35. {
  36. return System_executor::get_instance_references().check_executer(p_msg);
  37. }
  38. return Error_code::SUCCESS;
  39. }
  40. //处理消息, 需要子类重载
  41. Error_manager System_communication::execute_msg(Communication_message* p_msg)
  42. {
  43. return System_executor::get_instance_references().execute_msg(p_msg);
  44. }
  45. //定时封装发送消息, 一般为心跳和状态信息, 需要子类重载
  46. Error_manager System_communication::encapsulate_send_data()
  47. {
  48. Error_manager t_error;
  49. return System_executor::get_instance_references().encapsulate_send_status();
  50. /*
  51. message::Measure_request_msg t_measure_request_msg;
  52. t_measure_request_msg.mutable_base_info()->set_msg_type(message::Message_type::eLocate_request_msg);
  53. t_measure_request_msg.mutable_base_info()->set_timeout_ms(5000);
  54. t_measure_request_msg.mutable_base_info()->set_sender(message::Communicator::eMain);
  55. t_measure_request_msg.mutable_base_info()->set_receiver(message::Communicator::eMeasurer);
  56. t_measure_request_msg.set_command_id(123);
  57. t_measure_request_msg.set_terminal_id(1);
  58. string t_msg = t_measure_request_msg.SerializeAsString();
  59. System_communication::get_instance_references().encapsulate_msg(t_msg);
  60. */
  61. /*
  62. //创建一条状态消息
  63. message::Measure_status_msg t_measure_status_msg;
  64. t_measure_status_msg.mutable_base_info()->set_msg_type(message::Message_type::eLocate_status_msg);
  65. t_measure_status_msg.mutable_base_info()->set_timeout_ms(5000);
  66. t_measure_status_msg.mutable_base_info()->set_sender(message::Communicator::eMeasurer);
  67. t_measure_status_msg.mutable_base_info()->set_receiver(message::Communicator::eMain);
  68. Laser_manager::Laser_manager_status t_laser_manager_status = Laser_manager::get_instance_references().get_laser_manager_status();
  69. t_measure_status_msg.set_laser_manager_status((message::Laser_manager_status)t_laser_manager_status);
  70. std::vector<Laser_base*> & t_laser_vector = Laser_manager::get_instance_references().get_laser_vector();
  71. for (auto iter = t_laser_vector.begin(); iter != t_laser_vector.end(); ++iter)
  72. {
  73. Laser_statu t_laser_statu = (*iter)->get_laser_statu();
  74. t_measure_status_msg.add_laser_statu_vector((message::Laser_statu)t_laser_statu);
  75. }
  76. Locate_manager::Locate_manager_status t_locate_manager_status = Locate_manager::get_instance_references().get_locate_manager_status();
  77. t_measure_status_msg.set_locate_manager_status((message::Locate_manager_status)t_locate_manager_status);
  78. t_measure_status_msg.mutable_error_manager()->set_error_code(t_error.get_error_code());
  79. t_measure_status_msg.mutable_error_manager()->set_error_level((message::Error_level)t_error.get_error_level());
  80. t_measure_status_msg.mutable_error_manager()->set_error_description(t_error.get_error_description(), t_error.get_description_length());
  81. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_x(0);
  82. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_y(0);
  83. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_angle(0);
  84. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_length(0);
  85. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_width(0);
  86. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_height(0);
  87. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_wheel_base(0);
  88. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_wheel_width(0);
  89. t_measure_status_msg.mutable_locate_information_realtime()->set_locate_correct(0);
  90. string t_msg = t_measure_status_msg.SerializeAsString();
  91. System_communication::get_instance_references().encapsulate_msg(t_msg);
  92. */
  93. return Error_code::SUCCESS;
  94. }