diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2019-02-22 15:06:58 +0100 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2019-02-22 15:07:18 +0100 |
commit | 4f66eb2bc9038dbac490ac540cdfe0188c91f672 (patch) | |
tree | 111fa7ebcb642173211f10030cf50e40a0ed9a8c /tracker-wii | |
parent | c06048a7af347bf843bf25bd305cbbf4d6cec266 (diff) |
tracker/wii: debug to stderr w/ no debugger
Diffstat (limited to 'tracker-wii')
-rw-r--r-- | tracker-wii/wiiyourself/wiimote.cpp | 35 |
1 files changed, 19 insertions, 16 deletions
diff --git a/tracker-wii/wiiyourself/wiimote.cpp b/tracker-wii/wiiyourself/wiimote.cpp index 503a0783..7a5ee833 100644 --- a/tracker-wii/wiiyourself/wiimote.cpp +++ b/tracker-wii/wiiyourself/wiimote.cpp @@ -14,12 +14,11 @@ #include <new> #include <cstring> #include <cstdio> +#include <iterator> #include "wiimote.h" #include <setupapi.h> -extern "C" { #include <hidsdi.h>// from WinDDK -} #include <sys/types.h> // for _stat #include <sys/stat.h> // " @@ -46,8 +45,8 @@ template<class T> inline T square(const T& val) { return val * val; } // comment these to auto-strip their code from the library: // (they currently use OutputDebugString() via _TRACE() - change to suit) -# define TRACE _TRACE -# define WARN _TRACE +# define TRACE trace_ +# define WARN trace_ // uncomment any of these for deeper debugging: //#define DEEP_TRACE(fmt, ...) _TRACE(PREFIX _T("|") fmt _T("\n"), __VA_ARGS__) // VC 2005+ //#define DEEP_TRACE(fmt, ...) _TRACE(PREFIX _T("|") fmt _T("\n") , ##__VA_ARGS__) // mingw @@ -67,21 +66,25 @@ template<class T> inline T square(const T& val) { return val * val; } # define WARN(...) (void)0 #endif // ------------------------------------------------------------------------------------ -static void __cdecl _TRACE(const TCHAR* fmt, ...) +static void trace_(const char* fmt, ...) { - static TCHAR buffer[256]; - if (!fmt) return; + char buffer[256]; - va_list argptr; - va_start(argptr, fmt); -#ifdef _MSC_VER - _vsntprintf_s(buffer, ARRAY_ENTRIES(buffer), _TRUNCATE, fmt, argptr); -#else - _vsntprintf(buffer, ARRAY_ENTRIES(buffer), fmt, argptr); -#endif - va_end(argptr); + if (!fmt) + return; - OutputDebugString(buffer); + va_list ap; + va_start(ap, fmt); + vsnprintf(buffer, std::size(buffer), fmt, ap); + va_end(ap); + + if (IsDebuggerPresent()) + OutputDebugString(buffer); + else + { + fprintf(stderr, "%s\n", buffer); + fflush(stderr); + } } // ------------------------------------------------------------------------------------ |