#include "stdafx.h" void _OutputDebugString(TCHAR* lpOutputString, ...) { TCHAR OutMsg[MAX_LENGTH]; TCHAR format[MAX_LENGTH]; int i, j; va_list argptr; va_start(argptr, lpOutputString); for (i = 0, j = 0; lpOutputString[i] != '\0'; i++) { format[j++] = lpOutputString[i]; format[j] = '\0'; if (lpOutputString[i] != '%') continue; format[j++] = lpOutputString[++i]; format[j] = '\0'; switch (lpOutputString[i]) { // string case 's': { TCHAR* s = va_arg(argptr, TCHAR *); mir_sntprintf(OutMsg, SIZEOF(OutMsg), format, s); mir_tstrncpy(format, OutMsg, _countof(OutMsg)); j = (int)mir_tstrlen(format); mir_tstrcat(format, _T(" ")); break; } // character case 'c': { char c = (char)va_arg(argptr, int); mir_sntprintf(OutMsg, SIZEOF(OutMsg), format, c); mir_tstrncpy(format, OutMsg, _countof(OutMsg)); j = (int)mir_tstrlen(format); mir_tstrcat(format, _T(" ")); break; } // integer case 'd': { int d = va_arg(argptr, int); mir_sntprintf(OutMsg, SIZEOF(OutMsg), format, d); mir_tstrncpy(format, OutMsg, _countof(OutMsg)); j = (int)mir_tstrlen(format); mir_tstrcat(format, _T(" ")); break; } } format[j + 1] = '\0'; } mir_tstrcat(format, _T("\n")); OutputDebugString(format); va_end(argptr); }