From 0dea0a65b4cabd5910fb8747a0cb3935a27e6ec5 Mon Sep 17 00:00:00 2001 From: "jcampan@chromium.org" Date: Tue, 3 Feb 2009 23:20:59 +0000 Subject: This CL adds macro used to track the creation and destruction of HWNDs, in an attempt to detect potential double-delete. A double-delete of a HWND might be responsible for the crasher http://crbug.com/4714 Review URL: http://codereview.chromium.org/21018 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@9109 0039d316-1c4b-4281-b951-d872f2087c98 --- base/win_util.h | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'base/win_util.h') diff --git a/base/win_util.h b/base/win_util.h index 317c332..f6ce1c2 100644 --- a/base/win_util.h +++ b/base/win_util.h @@ -10,6 +10,8 @@ #include +#include "base/tracked.h" + namespace win_util { // NOTE: Keep these in order so callers can do things like @@ -102,6 +104,22 @@ std::wstring FormatMessage(unsigned messageid); // Uses the last Win32 error to generate a human readable message string. std::wstring FormatLastWin32Error(); +// These 2 methods are used to track HWND creation/destruction to investigate +// a mysterious crasher http://crbugs.com/4714 (crasher in on NCDestroy) that +// might be caused by a multiple delete of an HWND. +void NotifyHWNDCreation(const tracked_objects::Location& from_here, HWND hwnd); +void NotifyHWNDDestruction(const tracked_objects::Location& from_here, + HWND hwnd); + +#ifdef NDEBUG +#define TRACK_HWND_CREATION(hwnd) +#define TRACK_HWND_DESTRUCTION(hwnd) +#else +#define TRACK_HWND_CREATION(hwnd) win_util::NotifyHWNDCreation(FROM_HERE, hwnd) +#define TRACK_HWND_DESTRUCTION(hwnd) \ + win_util::NotifyHWNDDestruction(FROM_HERE, hwnd) +#endif + } // namespace win_util #endif // BASE_WIN_UTIL_H__ -- cgit v1.1