VC下没有支持可变参数的调试输出实现.今天捣鼓了半天做了一个简单的:)
// dgb_prt.h
#include <windows.h>
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
#define _DEBUG_INFO_FILE "gfx_dbg_info.txt" // 修改这里的输出文件
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
VOID _cdecl __DPrt(const WCHAR *fmt,
);
VOID _cdecl __RPrt(const WCHAR *fmt,
);
VOID _cdecl __ADPrt(BOOL, const WCHAR *fmt,
);
VOID _cdecl __ARPrt(BOOL, const WCHAR *fmt,
);
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
#ifndef NDEBUG
# define _DbgPrt __DPrt
#else
# define _DbgPrt __RPrt
#endif
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
#ifndef NDEBUG
# define _AstPrt __ADPrt
#else
# define _AstPrt __ARPrt
#endif
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// dbg_prt.cpp
// -------------------------------------------------------------------------
#define _STDOUT_FP (1)
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
#define _DEBUG_INFO_FILE "dbg_info.txt"
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// -------------------------------------------------------------------------
typedef struct __DbgPrtPara
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
FILE *pfp;
int pfd;
unsigned long pret;
} _DbgPrtPara, *_PDbgPrtPara;
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
_PDbgPrtPara __stdcall __DPrtInit()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
_PDbgPrtPara pDbgPara = (_PDbgPrtPara)malloc(sizeof(_DbgPrtPara));
pDbgPara->pfd = _dup(_STDOUT_FP);
pDbgPara->pfp = freopen(_DEBUG_INFO_FILE, "a+", stdout);
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
unsigned short buff[128] =
{'\0'};
_wstrtime(buff);
wprintf(L"%s: ", buff);
return pDbgPara;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
void __stdcall __DPrtClose(_PDbgPrtPara pDbgPara)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
fflush(pDbgPara->pfp);
fclose(pDbgPara->pfp);
_dup2(pDbgPara->pfd, _STDOUT_FP);
free(pDbgPara);
pDbgPara = NULL;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// -------------------------------------------------------------------------
__declspec(naked) void __DPrt(const unsigned short *fmt,
)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
#ifdef _M_IX86
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
__asm
{
call __DPrtInit
pop ebx
mov dword ptr [eax + 8], ebx
mov ebx, eax
call dword ptr [wprintf]
push ebx
mov eax, dword ptr [ebx + 8]
mov ebx, eax
call __DPrtClose
push ebx
ret
}
#endif
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// -------------------------------------------------------------------------
void __RPrt(const unsigned short *fmt,
)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// -------------------------------------------------------------------------
__declspec(naked) void __ADPrt(unsigned long, const unsigned short *fmt,
)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
#ifdef _M_IX86
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
__asm
{
mov eax, dword ptr [esp + 4]
cmp eax, 0
je EXE_TRUE
ret
EXE_TRUE:
call __DPrtInit
pop ebx
mov dword ptr [eax + 8], ebx
mov ebx, eax
pop eax
call dword ptr [wprintf]
push ebx
mov eax, dword ptr [ebx + 8]
mov ebx, eax
call __DPrtClose
sub esp, 4
push ebx
ret
}
#endif
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// -------------------------------------------------------------------------
void _cdecl __ARPrt(unsigned long, const unsigned short *fmt,
)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// -------------------------------------------------------------------------
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
当然,如果要实时看到输出,可以用 FindFirstChangeNotification、FindNextChangeNotification、FILE_NOTIFY_CHANGE_LAST_WRITE等来实现一个动态监视并输出的程序.
这样就有点象ddk里的DbgPrint了,呵呵.