90 lines
2.4 KiB
C++
90 lines
2.4 KiB
C++
|
|
|||
|
|
|||
|
#if (defined(_DEBUG) || defined(PCS_COMPLIANCE))
|
|||
|
|
|||
|
#include "interop.h"
|
|||
|
#include <stdio.h>
|
|||
|
#include "cpls.h"
|
|||
|
|
|||
|
static int g_nRefCount = 0;
|
|||
|
|
|||
|
LPInteropLogger INTEROP_EXPORT InteropLoad(CPLProtocol Protocol)
|
|||
|
{
|
|||
|
OutputDebugString("Loading CPLS\n");
|
|||
|
LPInteropLogger Logger = (LPInteropLogger) GlobalAlloc (GMEM_FIXED | GMEM_ZEROINIT, sizeof(InteropLogger));
|
|||
|
if (!(Logger))
|
|||
|
return NULL;
|
|||
|
UINT oldMode = SetErrorMode(SEM_NOOPENFILEERRORBOX);
|
|||
|
|
|||
|
(Logger)->hInst = LoadLibrary(DLLName);
|
|||
|
|
|||
|
SetErrorMode(oldMode);
|
|||
|
|
|||
|
if ((INT_PTR)(Logger)->hInst > HINSTANCE_ERROR)
|
|||
|
{
|
|||
|
g_nRefCount++;
|
|||
|
|
|||
|
#ifdef _DEBUG
|
|||
|
char buf[80];
|
|||
|
wsprintf (buf, "Loading Generic Protocol Logger: %s\n",DLLName);
|
|||
|
OutputDebugString(buf);
|
|||
|
#endif
|
|||
|
|
|||
|
(Logger)->CPLInitialize = (CPLInitialize_t)GetProcAddress((Logger)->hInst, "CPLInitialize");
|
|||
|
(Logger)->CPLUninitialize = (CPLUninitialize_t)GetProcAddress((Logger)->hInst, "CPLUninitialize");
|
|||
|
(Logger)->CPLOpen = (CPLOpen_t)GetProcAddress((Logger)->hInst, "CPLOpen");
|
|||
|
(Logger)->CPLClose = (CPLClose_t)GetProcAddress((Logger)->hInst, "CPLClose");
|
|||
|
(Logger)->CPLOutput = (CPLOutput_t)GetProcAddress((Logger)->hInst, "CPLOutput");
|
|||
|
Logger->g_ProtocolLogID = Logger->CPLInitialize(Protocol);
|
|||
|
Logger->g_ComplianceProtocolLogger = Logger->CPLOpen(Logger->g_ProtocolLogID,
|
|||
|
NULL,
|
|||
|
CPLS_CREATE | CPLS_APPEND);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
GlobalFree((Logger));
|
|||
|
(Logger) = NULL;
|
|||
|
#ifdef _DEBUG
|
|||
|
char buf[80];
|
|||
|
wsprintf (buf, "Loading Generic Protocol Logger %s Failed\n",DLLName);
|
|||
|
OutputDebugString(buf);
|
|||
|
#endif
|
|||
|
}
|
|||
|
|
|||
|
return Logger;
|
|||
|
}
|
|||
|
|
|||
|
void INTEROP_EXPORT InteropUnload(LPInteropLogger Logger)
|
|||
|
{
|
|||
|
#ifdef _DEBUG
|
|||
|
char buf[80];
|
|||
|
wsprintf (buf, "Unloading Generic Protocol Logger: %s\n",DLLName);
|
|||
|
OutputDebugString(buf);
|
|||
|
#endif
|
|||
|
|
|||
|
if ((Logger))
|
|||
|
{
|
|||
|
if ((INT_PTR)(Logger)->hInst > HINSTANCE_ERROR)
|
|||
|
{
|
|||
|
Logger->CPLClose(Logger->g_ComplianceProtocolLogger);
|
|||
|
Logger->CPLUninitialize(Logger->g_ProtocolLogID);
|
|||
|
if (--g_nRefCount <= 0)
|
|||
|
FreeLibrary((Logger)->hInst);
|
|||
|
}
|
|||
|
GlobalFree((Logger));
|
|||
|
(Logger) = NULL;
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
void INTEROP_EXPORT InteropOutput(LPInteropLogger Logger, BYTE* buf,
|
|||
|
int length, unsigned long userData)
|
|||
|
{
|
|||
|
if (!Logger)
|
|||
|
return;
|
|||
|
Logger->CPLOutput(Logger->g_ComplianceProtocolLogger, buf, length,userData);
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
#endif // #if (defined(_DEBUG) || defined(PCS_COMPLIANCE))
|
|||
|
|