X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/5d06f362eb30efce58dbeb5ea337b3c9d5ebc74b..d0960f6d3be27a47c2f4ba14542af6902c7e9ac7:/include/wx/msw/msvcrt.h diff --git a/include/wx/msw/msvcrt.h b/include/wx/msw/msvcrt.h index 5e757840a4..c1413a7571 100644 --- a/include/wx/msw/msvcrt.h +++ b/include/wx/msw/msvcrt.h @@ -22,7 +22,8 @@ // use debug CRT functions for memory leak detections in VC++ 5.0+ in debug // builds #undef wxUSE_VC_CRTDBG -#if defined(__WXDEBUG__) && defined(__VISUALC__) && (__VISUALC__ >= 1000) +#if defined(__WXDEBUG__) && defined(__VISUALC__) && (__VISUALC__ >= 1000) \ + && !defined(UNDER_CE) // it doesn't combine well with wxWin own memory debugging methods #if !wxUSE_GLOBAL_MEMORY_OPERATORS && !wxUSE_MEMORY_TRACING && !defined(__NO_VC_CRTDBG__) #define wxUSE_VC_CRTDBG @@ -35,28 +36,28 @@ #define _DEBUG #endif - // Need to undef new if including crtdbg.h which redefines new itself + // Need to undef new if including crtdbg.h which may redefine new itself #ifdef new #undef new #endif - // we need this to show file & line number of the allocation that caused - // the leak - #define _CRTDBG_MAP_ALLOC #include #ifndef _CRTBLD - // Need when builded with pure MS SDK + // Needed when building with pure MS SDK #define _CRTBLD #endif #include + #undef WXDEBUG_NEW + #define WXDEBUG_NEW new(_NORMAL_BLOCK, __FILE__, __LINE__) + // this define works around a bug with inline declarations of new, see // - // http://support.microsoft.com/support/kb/articles/Q140/8/58.asp + // http://support.microsoft.com/kb/q140858/ // - // for the details - #define new new( _NORMAL_BLOCK, __FILE__, __LINE__) + // for the details + #define new WXDEBUG_NEW #define wxCrtSetDbgFlag(flag) \ _CrtSetDbgFlag(_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG) | (flag))