mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
111 lines
2.5 KiB
111 lines
2.5 KiB
/*++
|
|
|
|
Copyright (c) 1990-1998 Microsoft Corporation, All Rights Reserved
|
|
|
|
Module Name:
|
|
|
|
DEBUG.C
|
|
|
|
++*/
|
|
|
|
#include <windows.h>
|
|
#include "immdev.h"
|
|
#include "fakeime.h"
|
|
|
|
#ifdef DEBUG
|
|
|
|
#ifdef FAKEIMEM
|
|
const LPTSTR g_szRegInfoPath = TEXT("software\\microsoft\\fakeime\\m");
|
|
#elif UNICODE
|
|
const LPTSTR g_szRegInfoPath = TEXT("software\\microsoft\\fakeime\\u");
|
|
#else
|
|
const LPTSTR g_szRegInfoPath = TEXT("software\\microsoft\\fakeime\\a");
|
|
#endif
|
|
|
|
int DebugPrint(LPCTSTR lpszFormat, ...)
|
|
{
|
|
int nCount;
|
|
TCHAR szMsg[1024];
|
|
|
|
va_list marker;
|
|
va_start(marker, lpszFormat);
|
|
nCount = wvsprintf(szMsg, lpszFormat, marker);
|
|
va_end(marker);
|
|
OutputDebugString(szMsg);
|
|
return nCount;
|
|
}
|
|
|
|
DWORD PASCAL GetDwordFromSetting(LPTSTR lpszFlag)
|
|
{
|
|
HKEY hkey;
|
|
DWORD dwRegType, dwData, dwDataSize, dwRet;
|
|
|
|
dwData = 0;
|
|
dwDataSize=sizeof(DWORD);
|
|
if (ERROR_SUCCESS == RegOpenKeyEx(HKEY_LOCAL_MACHINE, g_szRegInfoPath, 0, KEY_READ, &hkey)) {
|
|
dwRet = RegQueryValueEx(hkey, lpszFlag, NULL, &dwRegType, (LPBYTE)&dwData, &dwDataSize);
|
|
RegCloseKey(hkey);
|
|
}
|
|
MyDebugPrint((TEXT("Getting: %s=%#8.8x: dwRet=%#8.8x\n"), lpszFlag, dwData, dwRet));
|
|
return dwData;
|
|
}
|
|
|
|
void SetDwordToSetting(LPCTSTR lpszFlag, DWORD dwFlag)
|
|
{
|
|
HKEY hkey;
|
|
DWORD dwDataSize, dwRet;
|
|
|
|
if (ERROR_SUCCESS == RegOpenKeyEx(HKEY_LOCAL_MACHINE, g_szRegInfoPath, 0, KEY_WRITE, &hkey)) {
|
|
dwRet = RegSetValueEx(hkey, lpszFlag, 0, REG_DWORD, (CONST BYTE *) &dwFlag, sizeof(DWORD));
|
|
RegCloseKey(hkey);
|
|
}
|
|
MyDebugPrint((TEXT("Setting: %s=%#8.8x: dwRet=%#8.8x\n"), lpszFlag, dwFlag, dwRet));
|
|
}
|
|
|
|
void PASCAL SetGlobalFlags()
|
|
{
|
|
dwLogFlag = GetDwordFromSetting(TEXT("LogFlag"));
|
|
dwDebugFlag = GetDwordFromSetting(TEXT("DebugFlag"));
|
|
}
|
|
|
|
void PASCAL ImeLog(DWORD dwFlag, LPTSTR lpStr)
|
|
{
|
|
TCHAR szBuf[80];
|
|
|
|
if (dwFlag & dwLogFlag)
|
|
{
|
|
if (dwDebugFlag & DEBF_THREADID)
|
|
{
|
|
DWORD dwThreadId = GetCurrentThreadId();
|
|
wsprintf(szBuf, TEXT("ThreadID = %X "), dwThreadId);
|
|
OutputDebugString(szBuf);
|
|
}
|
|
|
|
OutputDebugString(lpStr);
|
|
OutputDebugString(TEXT("\r\n"));
|
|
}
|
|
}
|
|
|
|
#ifdef FAKEIMEM
|
|
void PASCAL MyOutputDebugStringW(LPWSTR lpw)
|
|
{
|
|
DWORD dwSize = (lstrlenW(lpw) + 1) * 2;
|
|
LPSTR lpStr;
|
|
int n;
|
|
|
|
lpStr = GlobalAlloc(GPTR, dwSize);
|
|
|
|
if (!lpStr)
|
|
return;
|
|
|
|
|
|
n = WideCharToMultiByte(CP_ACP, 0, lpw, lstrlenW(lpw), lpStr, dwSize, NULL, NULL);
|
|
|
|
*(lpStr + n) = '\0';
|
|
|
|
OutputDebugString(lpStr);
|
|
GlobalFree((HANDLE)lpStr);
|
|
}
|
|
#endif
|
|
|
|
#endif //DEBUG
|