00001
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 #include "precomp.h"
00032 #include "debug.h"
00033
00034
00035
00037
00039
00040 #define DEBUG_BUFFER_SIZE 1024
00041 #define PATH_SEPARATOR '\\'
00042
00043
00044
00045
00046 #ifdef VERBOSE_MSG
00047 #define DEBUG_LEVEL DBG_VERBOSE
00048 #elif TERSE_MSG
00049 #define DEBUG_LEVEL DBG_TERSE
00050 #elif WARNING_MSG
00051 #define DEBUG_LEVEL DBG_WARNING
00052 #elif ERROR_MSG
00053 #define DEBUG_LEVEL DBG_ERROR
00054 #elif RIP_MSG
00055 #define DEBUG_LEVEL DBG_RIP
00056 #elif NO_DBG_MSG
00057 #define DEBUG_LEVEL DBG_NONE
00058 #else
00059 #define DEBUG_LEVEL DBG_WARNING
00060 #endif
00061
00062
00063
00065
00067
00068 INT giDebugLevel = DEBUG_LEVEL;
00069
00070
00071
00072
00074
00076
00077 static BOOL DebugMessageV(LPCSTR lpszMessage, va_list arglist);
00078 static BOOL DebugMessageV(DWORD dwSize, LPCWSTR lpszMessage, va_list arglist);
00079
00080
00081
00082
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00108
00109 static BOOL DebugMessageV(LPCSTR lpszMessage, va_list arglist)
00110 {
00111 DWORD dwSize = DEBUG_BUFFER_SIZE;
00112 LPSTR lpszMsgBuf = NULL;
00113
00114
00115
00116 if( (NULL == lpszMessage)
00117 ||
00118 (0 == dwSize)
00119 )
00120 {
00121 return FALSE;
00122 }
00123
00124 do
00125 {
00126
00127 if(NULL != lpszMsgBuf)
00128 {
00129 delete[] lpszMsgBuf;
00130 dwSize *= 2;
00131 }
00132 lpszMsgBuf = new CHAR[dwSize + 1];
00133 if(NULL == lpszMsgBuf)
00134 return FALSE;
00135
00136
00137 } while (_vsnprintf_s(lpszMsgBuf, dwSize + 1, dwSize, lpszMessage, arglist) < 0);
00138
00139
00140 OutputDebugStringA(lpszMsgBuf);
00141
00142
00143 delete[] lpszMsgBuf;
00144
00145 return TRUE;
00146 }
00147
00148
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164
00165
00166
00167
00168
00169
00170
00171
00172
00174
00175 static BOOL DebugMessageV(DWORD dwSize, LPCWSTR lpszMessage, va_list arglist)
00176 {
00177 LPWSTR lpszMsgBuf;
00178
00179
00180
00181 if( (NULL == lpszMessage)
00182 ||
00183 (0 == dwSize)
00184 )
00185 {
00186 return FALSE;
00187 }
00188
00189
00190 lpszMsgBuf = new WCHAR[dwSize + 1];
00191 if(NULL == lpszMsgBuf)
00192 return FALSE;
00193
00194
00195 vswprintf_s(lpszMsgBuf, dwSize + 1, lpszMessage, arglist);
00196
00197
00198 OutputDebugStringW(lpszMsgBuf);
00199
00200
00201 delete[] lpszMsgBuf;
00202
00203 return TRUE;
00204 }
00205
00206
00208
00209
00210
00211
00212
00213
00214
00215
00216
00217
00218
00219
00220
00221
00222
00223
00224
00225
00226
00228
00229 BOOL DebugMessage(LPCSTR lpszMessage, ...)
00230 {
00231 BOOL bResult;
00232 va_list VAList;
00233
00234
00235
00236 va_start(VAList, lpszMessage);
00237 bResult = DebugMessageV(lpszMessage, VAList);
00238 va_end(VAList);
00239
00240 return bResult;
00241 }
00242
00243
00245
00246
00247
00248
00249
00250
00251
00252
00253
00254
00255
00256
00257
00258
00259
00260
00261
00262
00263
00265
00266 BOOL DebugMessage(LPCWSTR lpszMessage, ...)
00267 {
00268 BOOL bResult;
00269 va_list VAList;
00270
00271
00272
00273 va_start(VAList, lpszMessage);
00274 bResult = DebugMessageV(MAX_PATH, lpszMessage, VAList);
00275 va_end(VAList);
00276
00277 return bResult;
00278 }
00279
00280 void Dump(PPUBLISHERINFO pPublisherInfo)
00281 {
00282 VERBOSE(__TEXT("pPublisherInfo:\r\n"));
00283 VERBOSE(__TEXT("\tdwMode = %#x\r\n"), pPublisherInfo->dwMode);
00284 VERBOSE(__TEXT("\twMinoutlinePPEM = %d\r\n"), pPublisherInfo->wMinoutlinePPEM);
00285 VERBOSE(__TEXT("\twMaxbitmapPPEM = %d\r\n"), pPublisherInfo->wMaxbitmapPPEM);
00286 }
00287
00288 void Dump(POEMDMPARAM pOemDMParam)
00289 {
00290 VERBOSE(__TEXT("pOemDMParam:\r\n"));
00291 VERBOSE(__TEXT("\tcbSize = %d\r\n"), pOemDMParam->cbSize);
00292 VERBOSE(__TEXT("\tpdriverobj = %#x\r\n"), pOemDMParam->pdriverobj);
00293 VERBOSE(__TEXT("\thPrinter = %#x\r\n"), pOemDMParam->hPrinter);
00294 VERBOSE(__TEXT("\thModule = %#x\r\n"), pOemDMParam->hModule);
00295 VERBOSE(__TEXT("\tpPublicDMIn = %#x\r\n"), pOemDMParam->pPublicDMIn);
00296 VERBOSE(__TEXT("\tpPublicDMOut = %#x\r\n"), pOemDMParam->pPublicDMOut);
00297 VERBOSE(__TEXT("\tpOEMDMIn = %#x\r\n"), pOemDMParam->pOEMDMIn);
00298 VERBOSE(__TEXT("\tpOEMDMOut = %#x\r\n"), pOemDMParam->pOEMDMOut);
00299 VERBOSE(__TEXT("\tcbBufSize = %d\r\n"), pOemDMParam->cbBufSize);
00300 }
00301
00302 #ifndef KERNEL_MODE
00303 void Dump(PPROPSHEETUI_INFO pPSUIInfo)
00304 {
00305 VERBOSE(__TEXT("pPSUIInfo:\r\n"));
00306 VERBOSE(__TEXT("\tcbSize = %d\r\n"), pPSUIInfo->cbSize);
00307 VERBOSE(__TEXT("\tVersion = %#x\r\n"), pPSUIInfo->Version);
00308 VERBOSE(__TEXT("\tFlags = %#x\r\n"), pPSUIInfo->Flags);
00309 VERBOSE(__TEXT("\tReason = %d\r\n"), pPSUIInfo->Reason);
00310 VERBOSE(__TEXT("\thComPropSheet = %#x\r\n"), pPSUIInfo->hComPropSheet);
00311 VERBOSE(__TEXT("\tpfnComPropSheet = %#x\r\n"), pPSUIInfo->pfnComPropSheet);
00312 VERBOSE(__TEXT("\tlParamInit = %#x\r\n"), pPSUIInfo->lParamInit);
00313 VERBOSE(__TEXT("\tUserData = %#x\r\n"), pPSUIInfo->UserData);
00314 VERBOSE(__TEXT("\tResult = %#x\r\n"), pPSUIInfo->Result);
00315 }
00316 #endif
00317
00318
00319 PCSTR
00320 StripDirPrefixA(
00321 IN PCSTR pstrFilename
00322 )
00323
00324
00325
00326
00327
00328
00329
00330
00331
00332
00333
00334
00335
00336
00337
00338
00339
00340 {
00341 PCSTR pstr;
00342
00343 if (pstr = strrchr(pstrFilename, PATH_SEPARATOR))
00344 return pstr + 1;
00345
00346 return pstrFilename;
00347 }
00348
00349