error_code.h 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542
  1. //Error_code是错误码的底层通用模块,
  2. //功能:用作故障分析和处理。
  3. //用法:所有的功能接口函数return错误管理类,
  4. //然后上层判断分析错误码,并进行故障处理。
  5. #ifndef TEST_ERROR_ERROR_CODE_H
  6. #define TEST_ERROR_ERROR_CODE_H
  7. #include <string>
  8. #include <string.h>
  9. #include<iostream>
  10. //错误管理类转化为字符串 的前缀,固定长度为58
  11. //这个是由显示格式来确定的,如果要修改格式或者 Error_code长度超过8位,Error_level长度超过2位,折需要重新计算
  12. #define ERROR_NAMAGER_TO_STRING_FRONT_LENGTH 58
  13. //进程加锁的状态,
  14. enum Lock_status
  15. {
  16. UNLOCK = 0,
  17. LOCK = 1,
  18. };
  19. //设备使能状态,
  20. enum Able_status
  21. {
  22. UNABLE = 0,
  23. ENABLE = 1,
  24. };
  25. //数据是否为空
  26. enum Empty_status
  27. {
  28. NON_EMPTY = 0,
  29. EMPTY = 1,
  30. };
  31. //错误码的枚举,用来做故障分析
  32. enum Error_code
  33. {
  34. //成功,没有错误,默认值0
  35. SUCCESS = 0x00000000,
  36. //基本错误码,
  37. ERROR = 0x00000001,//错误
  38. PARTIAL_SUCCESS = 0x00000002,//部分成功
  39. WARNING = 0x00000003,//警告
  40. FAILED = 0x00000004,//失败
  41. NODATA = 0x00000010,//没有数据,传入参数容器内部没有数据时,
  42. INVALID_MESSAGE = 0x00000011, //无效的消息,
  43. PARSE_FAILED = 0x00000012,//解析失败
  44. TASK_TIMEOVER = 0x00000020,//任务超时
  45. RESPONSE_TIMEOUT = 0x00000021,//答复超时
  46. POINTER_IS_NULL = 0x00000101,//空指针
  47. PARAMETER_ERROR = 0x00000102,//参数错误,传入参数不符合规范时,
  48. POINTER_MALLOC_FAIL = 0x00000103,//手动分配内存失败
  49. CLASS_BASE_FUNCTION_CANNOT_USE = 0x00000201,//基类函数不允许使用,必须使用子类的
  50. CONTAINER_IS_TERMINATE = 0x00000301,//容器被终止
  51. // 错误码的规范,
  52. // 错误码是int型,32位,十六进制。
  53. // 例如0x12345678
  54. // 12表示功能模块,例如:laser雷达模块 框架制定
  55. // 34表示文件名称,例如:laser_livox.cpp 框架制定
  56. // 56表示具体的类,例如:class laser_livox 个人制定
  57. // 78表示类的函数,例如:laser_livox::start(); 个人制定
  58. // 注:错误码的制定从1开始,不要从0开始,
  59. // 0用作错误码的基数,用来位运算,来判断错误码的范围。
  60. // laser扫描模块
  61. LASER_ERROR_BASE = 0x01000000,
  62. // laser_base基类
  63. LASER_BASE_ERROR_BASE = 0x01010000,
  64. LASER_TASK_PARAMETER_ERROR = 0x01010001, //雷达基类模块, 任务输入参数错误
  65. LASER_CONNECT_FAILED, //雷达基类模块, 连接失败
  66. LASER_START_FAILED, //雷达基类模块, 开始扫描失败
  67. LASER_CHECK_FAILED, //雷达基类模块, 检查失败
  68. LASER_STATUS_BUSY, //雷达基类模块, 状态正忙
  69. LASER_STATUS_ERROR, //雷达基类模块, 状态错误
  70. LASER_TASK_OVER_TIME, //雷达基类模块, 任务超时
  71. LASER_QUEUE_ERROR, //雷达基类模块, 数据缓存错误
  72. // laser_livox.cpp的错误码
  73. LIVOX_ERROR_BASE = 0x01020000,
  74. LIVOX_START_FAILE, //livox模块,开始扫描失败
  75. LIVOX_TASK_TYPE_ERROR, //livox模块,任务类型错误
  76. lIVOX_CANNOT_PUSH_DATA, //livox模块,不能添加扫描的数据
  77. lIVOX_CHECK_FAILED, //livox模块,检查失败
  78. lIVOX_STATUS_BUSY, //livox模块,状态正忙
  79. lIVOX_STATUS_ERROR, //livox模块,状态错误
  80. //laser_manager 雷达管理模块
  81. LASER_MANAGER_ERROR_BASE = 0x01030000,
  82. LASER_MANAGER_READ_PROTOBUF_ERROR, //雷达管理模块,读取参数错误
  83. LASER_MANAGER_STATUS_BUSY, //雷达管理模块,状态正忙
  84. LASER_MANAGER_STATUS_ERROR, //雷达管理模块,状态错误
  85. LASER_MANAGER_TASK_TYPE_ERROR, //雷达管理模块,任务类型错误
  86. LASER_MANAGER_IS_NOT_READY, //雷达管理模块,不在准备状态
  87. LASER_MANAGER_TASK_OVER_TIME, //雷达管理模块,任务超时
  88. LASER_MANAGER_LASER_INDEX_ERRPR, //雷达管理模块,雷达索引错误,编号错误。
  89. LASER_MANAGER_LASER_INDEX_REPEAT, //雷达管理模块,需要扫描的雷达索引重复,可忽略的错误,提示作用
  90. //livox_driver 雷达livox驱动模块
  91. LIVOX_DRIVER_ERROR_BASE = 0x01040000,
  92. LIVOX_DRIVER_SN_REPEAT, //livox驱动模块, 雷达广播码重复
  93. LIVOX_DRIVER_SN_ERROR, //livox驱动模块, 雷达广播码错误
  94. LIVOX_SKD_INIT_FAILED, //livox驱动模块, livox_sdk初始化失败
  95. LIVOX_DRIVER_NOT_READY, //livox驱动模块, livox没有准备好.
  96. //PLC error code ...
  97. PLC_ERROR_BASE = 0x02010000,
  98. PLC_UNKNOWN_ERROR, //plc未知错误
  99. PLC_EMPTY_TASK, //plc任务为空
  100. PLC_IP_PORT_ERROR, //plc的ip端口错误
  101. PLC_SLAVE_ID_ERROR, //plc的身份id错误
  102. PLC_CONNECTION_FAILED, //PLC连接失败
  103. PLC_READ_FAILED, //plc读取失败
  104. PLC_WRITE_FAILED, //plc写入失败
  105. PLC_NOT_ENOUGH_DATA_ERROR, //PLC没有足够的数据错误
  106. //locate 定位模块,
  107. LOCATER_ERROR_BASE = 0x03000000,
  108. //LASER_MANAGER 定位管理模块
  109. LOCATER_MANAGER_ERROR_BASE = 0x03010000,
  110. LOCATER_MANAGER_READ_PROTOBUF_ERROR, //定位管理模块,读取参数错误
  111. LOCATER_MANAGER_STATUS_BUSY, //定位管理模块,状态正忙
  112. LOCATER_MANAGER_STATUS_ERROR, //定位管理模块,状态错误
  113. LOCATER_MANAGER_TASK_TYPE_ERROR, //定位管理模块,任务类型错误
  114. LOCATER_MANAGER_IS_NOT_READY, //定位管理模块,不在准备状态
  115. LOCATER_MANAGER_CLOUD_MAP_ERROR, //定位管理模块,任务输入点云map的error
  116. LOCATER_MANAGER_TASK_OVER_TIME, //定位管理模块,任务超时
  117. //Locater.cpp error
  118. LOCATER_ALGORITHM_ERROR_BASE = 0x03020000,
  119. LOCATER_TASK_INIT_CLOUD_EMPTY , //定位任务初始化点云为空
  120. LOCATER_TASK_ERROR, //定位任务错误
  121. LOCATER_TASK_INPUT_CLOUD_UNINIT, //定位任务输入点云为空
  122. LOCATER_INPUT_CLOUD_EMPTY, //定位输入点云为空
  123. LOCATER_YOLO_UNINIT, //定位yolo未初始化
  124. LOCATER_POINTSIFT_UNINIT, //定位POINTSIFT未初始化
  125. LOCATER_3DCNN_UNINIT, //定位3DCNN未初始化
  126. LOCATER_INPUT_YOLO_CLOUD_EMPTY, //定位输入yolo点云为空
  127. LOCATER_Y_OUT_RANGE_BY_PLC, //定位超出plc的限制范围
  128. LOCATER_MEASURE_HEIGHT_CLOUD_UNINIT, //定位测量高点云未初始化
  129. LOCATER_MEASURE_HEIGHT_CLOUD_EMPTY, //定位测量高点云为空
  130. LOCATER_INPUT_CLOUD_UNINIT, //定位输入点云未初始化
  131. //point sift from 0x03010100-0x030101FF
  132. LOCATER_SIFT_ERROR_BASE =0x03020100,
  133. LOCATER_SIFT_INIT_FAILED, //定位过滤模块,初始化失败
  134. LOCATER_SIFT_INPUT_CLOUD_UNINIT, //定位过滤模块,输入点云未初始化
  135. LOCATER_SIFT_INPUT_CLOUD_EMPTY, //定位过滤模块,输入点云为空
  136. LOCATER_SIFT_GRID_ERROR, //定位过滤模块,筛选网格错误
  137. LOCATER_SIFT_SELECT_ERROR, //定位过滤模块,筛选选择错误
  138. LOCATER_SIFT_CLOUD_VERY_LITTLE, //定位过滤模块,筛选点云很少
  139. LOCATER_SIFT_CREATE_INPUT_DATA_FAILED, //定位过滤模块,筛选创建输入数据失败
  140. LOCATER_SIFT_PREDICT_FAILED, //定位过滤模块,预测失败
  141. LOCATER_SIFT_PREDICT_TIMEOUT, //定位过滤模块,预测超时
  142. LOCATER_SIFT_PREDICT_NO_WHEEL_POINT, //定位过滤模块,预测结果没有车轮点云
  143. LOCATER_SIFT_PREDICT_NO_CAR_POINT, //定位过滤模块,预测结果没有车身点云
  144. LOCATER_SIFT_FILTE_OBS_FAILED, //定位过滤模块,过滤OBS失败
  145. LOCATER_SIFT_INPUT_BOX_PARAMETER_FAILED, //定位过滤模块,输入范围参数错误
  146. // //yolo
  147. // LOCATER_YOLO_ERROR_BASE =0x03020200,
  148. // LOCATER_YOLO_DETECT_FAILED,
  149. // LOCATER_YOLO_DETECT_NO_TARGET,
  150. // LOCATER_YOLO_PARAMETER_INVALID,
  151. // LOCATER_YOLO_INPUT_CLOUD_UNINIT,
  152. //3dcnn from 0x03010300-0x030103FF
  153. LOCATER_3DCNN_ERROR_BASE =0x03020300,
  154. LOCATER_3DCNN_INIT_FAILED, //定位3DCNN模块,初始化失败
  155. LOCATER_3DCNN_INPUT_CLOUD_UNINIT, //定位3DCNN模块,输入点云未初始化
  156. LOCATER_3DCNN_INPUT_CLOUD_EMPTY, //定位3DCNN模块,输入点云为空
  157. LOCATER_3DCNN_INPUT_CLOUD_MAP_ERROR, //定位3DCNN模块,输入点云的map错误
  158. LOCATER_3DCNN_PCA_OUT_ERROR, //定位3DCNN模块,pca错误
  159. LOCATER_3DCNN_EXTRACT_RECT_ERROR, //定位3DCNN模块,提取矩形错误
  160. LOCATER_3DCNN_RECT_SIZE_ERROR, //定位3DCNN模块,矩形范围错误
  161. LOCATER_3DCNN_PREDICT_FAILED, //定位3DCNN模块,预测失败
  162. LOCATER_3DCNN_VERIFY_RECT_FAILED_3, //定位3DCNN模块,验证矩形失败3
  163. LOCATER_3DCNN_VERIFY_RECT_FAILED_4, //定位3DCNN模块,验证矩形失败4
  164. LOCATER_3DCNN_KMEANS_FAILED, //定位3DCNN模块,k均值失败
  165. LOCATER_3DCNN_IIU_FAILED, //定位3DCNN模块,IIU失败
  166. LOCATER_3DCNN_PCA_OUT_CLOUD_EMPTY, //定位3DCNN模块,pca输出点云为空
  167. //System_manager error from 0x04010000-0x0401FFFF
  168. SYSTEM_READ_PARAMETER_ERROR=0x04010100,
  169. SYSTEM_PARAMETER_ERROR,
  170. SYSTEM_INPUT_TERMINOR_NO_LASERS,
  171. //terminor_command_executor.cpp from 0x04010200-0x040102FF
  172. TERMINOR_NOT_READY=0x04010200,
  173. TERMINOR_INPUT_LASER_NULL,
  174. TERMINOR_NOT_CONTAINS_LASER,
  175. TERMINOR_INPUT_PLC_NULL,
  176. TERMINOR_INPUT_LOCATER_NULL,
  177. TERMINOR_CREATE_WORKING_THREAD_FAILED,
  178. TERMINOR_FORCE_QUIT,
  179. TERMINOR_LASER_TIMEOUT,
  180. TERMINOR_POST_PLC_TIMEOUT,
  181. TERMINOR_CHECK_RESULTS_ERROR,
  182. ////Hardware limit from 0x05010000 - 0x0501ffff
  183. ///railing.cpp from 0x05010100-0x050101ff
  184. HARDWARE_LIMIT_LEFT_RAILING=0x05010100, //左栏杆限制
  185. HARDWARE_LIMIT_RAILING_PARAMETER_ERROR,
  186. HARDWARE_LIMIT_RAILING_ERROR,
  187. HARDWARE_LIMIT_CENTER_X_LEFT,
  188. HARDWARE_LIMIT_CENTER_X_RIGHT,
  189. HARDWARE_LIMIT_CENTER_Y_TOP,
  190. HARDWARE_LIMIT_CENTER_Y_BOTTOM,
  191. HARDWARE_LIMIT_HEIGHT_OUT_RANGE,
  192. HARDWARE_LIMIT_ANGLE_OUT_RANGE,
  193. //termonal_limit from 0x05010200-0x050102ff
  194. HARDWARE_LIMIT_TERMINAL_LEFT_ERROR,
  195. HARDWARE_LIMIT_TERMINAL_RIGHT_ERROR,
  196. HARDWARE_LIMIT_TERMINAL_LR_ERROR,
  197. WANJI_LIDAR_DEVICE_ERROR_BASE=0x06080000, //万集设备模块,错误基类
  198. WANJI_LIDAR_DEVICE_STATUS_BUSY, //万集设备模块,状态正忙
  199. WANJI_LIDAR_DEVICE_STATUS_ERROR, //万集设备模块,状态错误
  200. WANJI_LIDAR_DEVICE_TASK_TYPE_ERROR, //万集设备模块,任务类型错误
  201. WANJI_LIDAR_DEVICE_TASK_OVER_TIME, //万集设备模块,任务超时
  202. WANJI_LIDAR_DEVICE_NO_CLOUD, //万集设备模块,没有点云
  203. //wj_lidar error from 0x06010000-0x0601FFFF
  204. WJ_LIDAR_COMMUNICATION_ERROR_BASE=0x06010000,
  205. WJ_LIDAR_COMMUNICATION_UNINITIALIZED, //万集通信,未初始化
  206. WJ_LIDAR_COMMUNICATION_DISCONNECT, //万集通信,断连
  207. WJ_LIDAR_COMMUNICATION_FAULT, //万集通信,故障
  208. WJ_LIDAR_CONNECT_FAILED,
  209. WJ_LIDAR_UNINITIALIZED,
  210. WJ_LIDAR_READ_FAILED,
  211. WJ_LIDAR_WRITE_FAILED,
  212. WJ_LIDAR_GET_CLOUD_TIMEOUT,
  213. //wj lidar protocol error from 0x06020000-0x0602FFFF
  214. WJ_PROTOCOL_ERROR_BASE=0x06020000,
  215. WJ_PROTOCOL_STATUS_BUSY, //万集解析, 状态正忙
  216. WJ_PROTOCOL_STATUS_ERROR, //系统执行模块, 状态错误
  217. WJ_PROTOCOL_INTEGRITY_ERROR,
  218. WJ_PROTOCOL_PARSE_FAILED,
  219. WJ_PROTOCOL_EMPTY_PACKAGE,
  220. WJ_PROTOCOL_EXCEED_MAX_SIZE,
  221. //wj region detect error from 0x06030000-0x0603FFFF
  222. WJ_REGION_ERROR_BASE = 0x06030000,
  223. WJ_REGION_EMPTY_CLOUD,
  224. WJ_REGION_EMPTY_NO_WHEEL_INFORMATION,
  225. WJ_REGION_RECTANGLE_ANGLE_ERROR,
  226. WJ_REGION_RECTANGLE_SIZE_ERROR,
  227. WJ_REGION_RECTANGLE_SYMMETRY_ERROR,
  228. WJ_REGION_CLUSTER_SIZE_ERROR,
  229. //wj manager error from 0x06040000-0x0604FFFF
  230. WJ_MANAGER_UNINITIALIZED=0x06040000,
  231. WJ_MANAGER_LIDAR_DISCONNECTED,
  232. WJ_MANAGER_PLC_DISCONNECTED,
  233. WJ_MANAGER_EMPTY_CLOUD,
  234. WJ_MANAGER_READ_PROTOBUF_ERROR, //万集管理模块,读取参数错误
  235. WJ_MANAGER_INIT_REPEAT, //万集管理模块,重复初始化
  236. WJ_MANAGER_TASK_TYPE_ERROR, //万集管理模块,任务类型错误
  237. WJ_MANAGER_STATUS_BUSY, //万集管理模块,状态正忙
  238. WJ_MANAGER_STATUS_ERROR, //万集管理模块,状态错误
  239. WJ_MANAGER_LASER_INDEX_ERRPR, //万集管理模块,雷达索引错误,编号错误。
  240. WJ_MANAGER_LASER_INDEX_REPEAT, //万集管理模块,需要扫描的雷达索引重复,可忽略的错误,提示作用
  241. WJ_MANAGER_TASK_OVER_TIME, //万集管理模块,任务超时
  242. WJ_LIDAR_TASK_EMPTY_RESULT=0x06050000,
  243. WJ_LIDAR_TASK_EMPTY_TASK,
  244. WJ_LIDAR_TASK_WRONG_TYPE,
  245. WJ_LIDAR_TASK_INVALID_TASK,
  246. WJ_LIDAR_TASK_MEASURE_FAILED,
  247. //task module, 任务模块 error from 0x10010000-0x1001FFFF
  248. TASK_MODULE_ERROR_BASE = 0x10010000,
  249. TASK_TYPE_IS_UNKNOW,
  250. TASK_NO_RECEIVER,
  251. //Communication module, 通信模块
  252. COMMUNICATION_BASE_ERROR_BASE = 0x11010000,
  253. COMMUNICATION_READ_PROTOBUF_ERROR, //模块,读取参数错误
  254. COMMUNICATION_BIND_ERROR,
  255. COMMUNICATION_CONNECT_ERROR,
  256. COMMUNICATION_ANALYSIS_TIME_OUT, //解析超时,
  257. COMMUNICATION_EXCUTER_IS_BUSY, //处理器正忙, 请稍等
  258. //system module, 系统模块
  259. SYSTEM_EXECUTOR_ERROR_BASE = 0x12010000, //系统执行模块,
  260. SYSTEM_EXECUTOR_PARSE_ERROR, //系统执行模块, 解析消息错误
  261. SYSTEM_EXECUTOR_STATUS_BUSY, //系统执行模块, 状态正忙
  262. SYSTEM_EXECUTOR_STATUS_ERROR, //系统执行模块, 状态错误
  263. SYSTEM_EXECUTOR_CHECK_ERROR, //系统执行模块, 检查错误
  264. LOCATER_MSG_TABLE_NOT_EXIST ,
  265. LOCATER_MSG_RESPONSE_TYPE_ERROR,
  266. LOCATER_MSG_RESPONSE_INFO_ERROR,
  267. LOCATER_MSG_REQUEST_INVALID,
  268. LOCATER_MSG_RESPONSE_HAS_NO_REQUEST,
  269. //Dispatch 调度 模块 错误码
  270. DISPATCH_ERROR_BASE = 0x13000000,
  271. //Dispatch_manager 调度管理模块 错误码
  272. DISPATCH_MANAGER_ERROR_BASE = 0x13010000,
  273. DISPATCH_MANAGER_READ_PROTOBUF_ERROR, //调度管理模块,读取参数错误
  274. DISPATCH_MANAGER_STATUS_BUSY, //调度管理模块,状态正忙
  275. DISPATCH_MANAGER_STATUS_ERROR, //调度管理模块,状态错误
  276. DISPATCH_MANAGER_TASK_TYPE_ERROR, //调度管理模块,任务类型错误
  277. DISPATCH_MANAGER_IS_NOT_READY, //调度管理模块,不在准备状态
  278. CARRIER_ERROR_BASE = 0x13020000,
  279. CARRIER_READ_PROTOBUF_ERROR, //搬运器模块,读取参数错误
  280. CARRIER_STATUS_BUSY, //搬运器模块,状态正忙
  281. CARRIER_STATUS_ERROR, //搬运器模块,状态错误
  282. CARRIER_STATUS_DISCONNECT, //搬运器模块,状态断连
  283. CARRIER_TASK_TYPE_ERROR, //搬运器模块,任务类型错误
  284. CARRIER_TASK_OVER_TIME, //搬运器模块,任务超时
  285. CARRIER_IS_NOT_READY, //搬运器模块,不在准备状态
  286. CARRIER_RESPONS_ERROR, //搬运器模块,指令的执行失败
  287. CARRIER_TASK_NOTHINGNESS, //搬运器模块,任务不存在
  288. //snap7 通信模块 错误码
  289. SNAP7_ERROR_BASE = 0x1401000,
  290. SNAP7_READ_PROTOBUF_ERROR, //snap7通信模块,读取参数错误
  291. SNAP7_CONNECT_ERROR, //snap7通信模块,连接错误
  292. SNAP7_DISCONNECT_ERROR, //snap7通信模块,断连错误
  293. SNAP7_READ_ERROR, //snap7通信模块,读取错误
  294. SNAP7_WRITE_ERROR, //snap7通信模块,写入错误
  295. SNAP7_ANALYSIS_TIME_OUT, //解析超时,
  296. SNAP7_EXCUTER_IS_BUSY, //处理器正忙, 请稍等
  297. };
  298. //错误等级,用来做故障处理
  299. enum Error_level
  300. {
  301. // 正常,没有错误,默认值0
  302. NORMAL = 0,
  303. // 轻微故障,可忽略的故障,NEGLIGIBLE_ERROR
  304. // 提示作用,不做任何处理,不影响代码的流程,
  305. // 用作一些不重要的事件,即使出错也不会影响到系统功能,
  306. // 例如:文件保存错误,等
  307. NEGLIGIBLE_ERROR = 1,
  308. // 一般故障,MINOR_ERROR
  309. // 用作底层功能函数的错误返回,表示该功能函数执行失败,
  310. // 返回给应用层之后,需要做故障分析和处理,
  311. // 例如:雷达数据传输失败,应用层就需要进行重新扫描,或者重连,或者重置参数等。
  312. MINOR_ERROR = 2,
  313. // 严重故障,MAJOR_ERROR
  314. // 用作应用层的任务事件的结果,表示该功能模块失败。
  315. // 通常是底层函数返回一般故障之后,应用层无法处理并解决故障,此时就要进行故障升级,
  316. // 从一般故障升级为严重故障,然后进行回退流程,回退已经执行的操作,最终回到故障待机状态。
  317. // 需要外部清除故障,并复位至正常待机状态,才能恢复功能的使用。
  318. // 例如:雷达扫描任务失败,且无法自动恢复。
  319. MAJOR_ERROR = 3,
  320. // 致命故障,CRITICAL_ERROR
  321. // 系统出现致命错误。导致系统无法正常运行,
  322. // 此时系统应该紧急停机,执行紧急流程,快速停机。
  323. // 此时不允许再执行任何函数和任务指令,防止系统故障更加严重。
  324. // 也不需要做任何错误处理了,快速执行紧急流程。
  325. // 例如:内存错误,进程挂死,关键设备失控,监控设备报警,等
  326. CRITICAL_ERROR = 4,
  327. };
  328. class Error_manager
  329. {
  330. public://外部接口函数
  331. //构造函数
  332. Error_manager();
  333. //拷贝构造
  334. Error_manager(const Error_manager & error_manager);
  335. //赋值构造
  336. Error_manager(Error_code error_code, Error_level error_level = NORMAL,
  337. const char* p_error_description = NULL, int description_length = 0);
  338. //赋值构造
  339. Error_manager(Error_code error_code, Error_level error_level , std::string & error_aggregate_string);
  340. //析构函数
  341. ~Error_manager();
  342. //初始化
  343. void error_manager_init();
  344. //初始化
  345. void error_manager_init(Error_code error_code, Error_level error_level = NORMAL,
  346. const char* p_error_description = NULL, int description_length = 0);
  347. //初始化
  348. void error_manager_init(Error_code error_code, Error_level error_level , std::string & error_aggregate_string);
  349. //重置
  350. void error_manager_reset(Error_code error_code, Error_level error_level = NORMAL,
  351. const char* p_error_description = NULL, int description_length = 0);
  352. //重置
  353. void error_manager_reset(Error_code error_code, Error_level error_level , std::string & error_aggregate_string);
  354. //重置
  355. void error_manager_reset(const Error_manager & error_manager);
  356. //清除所有内容
  357. void error_manager_clear_all();
  358. //重载=
  359. Error_manager& operator=(const Error_manager & error_manager);
  360. //重载=,支持Error_manager和Error_code的直接转化,会清空错误等级和描述
  361. Error_manager& operator=(Error_code error_code);
  362. //重载==
  363. bool operator==(const Error_manager & error_manager);
  364. //重载==,支持Error_manager和Error_code的直接比较
  365. bool operator==(Error_code error_code);
  366. //重载!=
  367. bool operator!=(const Error_manager & error_manager);
  368. //重载!=,支持Error_manager和Error_code的直接比较
  369. bool operator!=(Error_code error_code);
  370. //重载<<,支持cout<<
  371. friend std::ostream & operator<<(std::ostream &out, Error_manager &error_manager);
  372. //获取错误码
  373. Error_code get_error_code();
  374. //获取错误等级
  375. Error_level get_error_level();
  376. //获取错误描述的指针,(浅拷贝)
  377. char* get_error_description();
  378. int get_description_length();
  379. //复制错误描述,(深拷贝)
  380. //output:p_error_description 错误描述的字符串指针,不可以为NULL,必须要有实际的内存
  381. //output:description_length 错误描述的字符串长度,不可以为0,长度最好足够大,一般256即可。
  382. void copy_error_description(const char* p_error_description, int description_length);
  383. //复制错误描述,(深拷贝)
  384. //output:error_description_string 错误描述的string
  385. void copy_error_description(std::string & error_description_string);
  386. //设置错误码
  387. void set_error_code(Error_code error_code);
  388. //比较错误等级并升级,取高等级的结果
  389. void set_error_level_up(Error_level error_level);
  390. //比较错误等级并降级,取低等级的结果
  391. void set_error_level_down(Error_level error_level);
  392. //错误等级,设定到固定值
  393. void set_error_level_location(Error_level error_level);
  394. //设置错误描述
  395. void set_error_description(const char* p_error_description, int description_length = 0);
  396. //设置错误描述
  397. void set_error_description(std::string & error_description_string);
  398. //尾部追加错误描述
  399. void add_error_description(const char* p_error_description, int description_length = 0);
  400. //尾部追加错误描述
  401. void add_error_description(std::string & error_description_string);
  402. //比较错误是否相同,
  403. // 注:只比较错误码和等级
  404. bool is_equal_error_manager(const Error_manager & error_manager);
  405. //比较并覆盖错误,讲低级错误转为字符串存放于描述中,
  406. //如果错误相同,则保留this的,将输入参数转入描述。
  407. void compare_and_cover_error(const Error_manager & error_manager);
  408. //比较并覆盖错误,讲低级错误转为字符串存放于描述中,
  409. //如果错误相同,则保留this的,将输入参数转入描述。
  410. void compare_and_cover_error( Error_manager * p_error_manager);
  411. //将所有的错误信息,格式化为字符串,用作日志打印。
  412. //output:p_error_description 错误汇总的字符串指针,不可以为NULL,必须要有实际的内存
  413. //output:description_length 错误汇总的字符串长度,不可以为0,长度最好足够大,一般256即可。
  414. void translate_error_to_string(char* p_error_aggregate, int aggregate_length);
  415. //output:error_description_string 错误汇总的string
  416. void translate_error_to_string(std::string & error_aggregate_string);
  417. //错误码转字符串的简易版,可支持cout<<
  418. //return 错误汇总的string
  419. std::string to_string();
  420. protected:
  421. Error_code m_error_code; //错误码
  422. Error_level m_error_level; //错误等级
  423. char* pm_error_description; //错误描述
  424. int m_description_length; //错误描述的字符长度
  425. protected://内部功能函数
  426. public:
  427. //释放错误描述的内存,
  428. void free_description();
  429. //重新分配错误描述的内存,并从外部拷贝新的(深拷贝)
  430. //input:p_error_description 错误描述的字符串指针,可以为NULL,
  431. //input:description_length 错误描述的字符串长度,如果为0,则从p_error_description里面获取有效的长度
  432. void reallocate_memory_and_copy_string(const char* p_error_description, int description_length = 0);
  433. //重新分配错误描述的内存,并从外部拷贝新的(深拷贝)
  434. //input:error_aggregate_string 错误描述的string
  435. void reallocate_memory_and_copy_string(std::string & error_aggregate_string);
  436. };
  437. #endif //TEST_ERROR_ERROR_CODE_H