#pragma once // 下列 ifdef 块是创建使从 DLL 导出更简单的 // 宏的标准方法。此 DLL 中的所有文件都是用命令行上定义的 CODEACQDPC_EXPORTS // 符号编译的。在使用此 DLL 的 // 任何其他项目上不应定义此符号。这样,源文件中包含此文件的任何其他项目都会将 // CODEACQDPC_API 函数视为是从 DLL 导入的,而此 DLL 则将用此宏定义的 // 符号视为是被导出的。 #ifndef CODEACQDPC_EXPORTS #ifdef _WIN64 #ifdef _DEBUG #pragma comment(lib, "CodeAcqDPCX64D.lib") #else #pragma comment(lib, "CodeAcqDPCX64.lib") #endif #else #ifdef _DEBUG #pragma comment(lib, "CodeAcqDPCD.lib") #else #pragma comment(lib, "CodeAcqDPC.lib") #endif #endif #endif #include "LogicDriver.h" #ifdef CODEACQDPC_EXPORTS #define CODEACQDPC_API __declspec(dllexport) #define CODEACQDPC_C_API extern "C" __declspec(dllexport) #else #define CODEACQDPC_API __declspec(dllimport) #define CODEACQDPC_C_API extern "C" __declspec(dllimport) #endif CODEACQDPC_C_API DriverDPC* GetDriverDPC(); CODEACQDPC_C_API void ReleaseDriverDPC(DriverDPC *p); class CODEACQDPC_API CodeAcqDPC : public LogicDriver { std::string *m_pWorkpath; public: CodeAcqDPC(void); virtual ~CodeAcqDPC(void); virtual bool DriverEntry(ResDataObject &Configuration); virtual bool Driver_Probe(ResDataObject &HardwareInfo); virtual bool SYSTEM_CALL SetDriverWorkPath(const char * PARAM_IN pWorkPath); virtual PVOID SYSTEM_CALL LoadDriver();//无根节点 virtual void SYSTEM_CALL UnloadDriver(); virtual DWORD SYSTEM_CALL OnNotify(HANDLE evtList[], DWORD count); virtual bool SYSTEM_CALL SetDeviceWorkPath(const char * PARAM_IN pWorkPath); //逻辑设备树的加载和卸载 virtual PVOID SYSTEM_CALL LoadLogicDevices(); virtual void SYSTEM_CALL UnloadLogicDevices(); virtual bool Device_Probe(ResDataObject &HardwareInfo); };