GeneratorDriver.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. #pragma once
  2. // 下列 ifdef 块是创建使从 DLL 导出更简单的
  3. // 宏的标准方法。此 DLL 中的所有文件都是用命令行上定义的 GENERATORDRIVER_EXPORTS
  4. // 符号编译的。在使用此 DLL 的
  5. // 任何其他项目上不应定义此符号。这样,源文件中包含此文件的任何其他项目都会将
  6. // GENERATORDRIVER_API 函数视为是从 DLL 导入的,而此 DLL 则将用此宏定义的
  7. // 符号视为是被导出的。
  8. #ifndef GENERATORDRIVER_EXPORTS
  9. #ifdef _WIN64
  10. #ifdef _DEBUG
  11. #pragma comment(lib, "GeneratorDriverX64D.lib")
  12. #else
  13. #pragma comment(lib, "GeneratorDriverX64.lib")
  14. #endif
  15. #else
  16. #ifdef _DEBUG
  17. #pragma comment(lib, "GeneratorDriverD.lib")
  18. #else
  19. #pragma comment(lib, "GeneratorDriver.lib")
  20. #endif
  21. #endif
  22. #endif
  23. #include "LogicDriver.h"
  24. #include "Generator_Model_Def.h"
  25. #ifdef GENERATORDRIVER_EXPORTS
  26. #define GENERATORDRIVER_API __declspec(dllexport)
  27. #define GENERATORDRIVER_C_API extern "C" __declspec(dllexport)
  28. #else
  29. #define GENERATORDRIVER_API __declspec(dllimport)
  30. #define GENERATORDRIVER_C_API extern "C" __declspec(dllimport)
  31. #endif
  32. // 此类是从 GeneratorDriver.dll 导出的
  33. class GENERATORDRIVER_API GeneratorDriver :public LogicDriver
  34. {
  35. //ExamModeList
  36. GenExamModeInfoListEx *m_pExamModeList;
  37. //Cur Exam Mode
  38. ResDataObject *m_pCurrentExamMode;
  39. //Generator Status
  40. ResDataObject *m_pGeneratorStatus;
  41. public:
  42. GeneratorDriver(void);
  43. virtual ~GeneratorDriver(void);
  44. ConfigInfo *m_pGenVender;
  45. ConfigInfo *m_pGenModel;
  46. ConfigInfo *m_pGenSyncType;
  47. ConfigInfo *m_pGenSCFType;
  48. ConfigInfo *m_pGenSCFPort;
  49. ConfigInfo *m_pGenSCFBaudrate;
  50. ConfigInfo *m_pGenSCFBytesize;
  51. ConfigInfo *m_pGenSCFParity;
  52. ConfigInfo *m_pGenSCFStopbits;
  53. ConfigInfo *m_pGenWSTable;
  54. ConfigInfo *m_pGenWSWall;
  55. ConfigInfo *m_pGenWSFree;
  56. ConfigInfo *m_pGenWSTomo;
  57. ConfigInfo *m_pGenWSConventional;
  58. ConfigInfo *m_pGenSynTable;
  59. ConfigInfo *m_pGenSynWall;
  60. ConfigInfo *m_pGenSynFree;
  61. ConfigInfo *m_pGenSynTomo;
  62. ConfigInfo *m_pGenSynConventional;
  63. ConfigInfo *m_pGenConsoleRole;
  64. ConfigInfo *m_pGenIsConnect;
  65. ResDataObject* m_pDeviceConfig;
  66. //基本接口
  67. virtual bool SYSTEM_CALL GetDeviceType(GUID &DevType);
  68. //get device resource
  69. virtual RET_STATUS SYSTEM_CALL GetDeviceResource(ResDataObject PARAM_OUT *pDeviceResource);
  70. virtual RET_STATUS SYSTEM_CALL GetSEQResource(ResDataObject PARAM_OUT *pDeviceResource);
  71. //ResourceCommand Request In and Response Out
  72. virtual RET_STATUS SYSTEM_CALL Request(ResDataObject PARAM_IN *pRequest, ResDataObject PARAM_OUT *pResponse);
  73. //notify to lower layer
  74. virtual RET_STATUS SYSTEM_CALL CmdToLogicDev(ResDataObject PARAM_IN *pCmd);
  75. //对象接口
  76. virtual bool SYSTEM_CALL DriverEntry(ResDataObject& PARAM_IN Configuration);
  77. //Actions
  78. virtual RET_STATUS DATA_ACTION DelExamMode(const char *pExamKey);
  79. virtual RET_STATUS DATA_ACTION SelectExamMode(const char *pExamKey);
  80. virtual RET_STATUS DATA_ACTION AddExamMode(const char *pExamKey, DWORD WSIndex, WORD SYNCMode, WORD BUCKYIndex, WORD AECChannel);
  81. virtual RET_STATUS DATA_ACTION UpdateExamMode(const char *pExamKey, DWORD WSIndex, WORD SYNCMode, WORD BUCKYIndex, WORD AECChannel);
  82. virtual RET_STATUS DATA_ACTION GetDeviceConfig(ResDataObject PARAM_OUT *pDeviceConfig);
  83. virtual RET_STATUS DATA_ACTION SetDeviceConfig(ResDataObject PARAM_IN *DeviceConfig);
  84. virtual RET_STATUS SYSTEM_CALL EnterExam();
  85. virtual RET_STATUS SYSTEM_CALL ExitExam();
  86. GENERATOR_STATUS OEM_IF GetGeneratorStatus();
  87. RET_STATUS OEM_IF SetGeneratorStatus(GENERATOR_STATUS status);
  88. };