summaryrefslogtreecommitdiffstats
path: root/base
diff options
context:
space:
mode:
Diffstat (limited to 'base')
-rw-r--r--base/win_util.cc63
-rw-r--r--base/win_util.h18
2 files changed, 0 insertions, 81 deletions
diff --git a/base/win_util.cc b/base/win_util.cc
index e18007b..cfd7f2b 100644
--- a/base/win_util.cc
+++ b/base/win_util.cc
@@ -4,15 +4,12 @@
#include "base/win_util.h"
-#include <map>
#include <sddl.h>
#include "base/logging.h"
#include "base/registry.h"
#include "base/scoped_handle.h"
-#include "base/singleton.h"
#include "base/string_util.h"
-#include "base/tracked.h"
namespace win_util {
@@ -364,66 +361,6 @@ std::wstring FormatLastWin32Error() {
return FormatMessage(GetLastError());
}
-typedef std::map<HWND, tracked_objects::Location> HWNDInfoMap;
-struct HWNDBirthMapTrait : public DefaultSingletonTraits<HWNDInfoMap> {
-};
-struct HWNDDeathMapTrait : public DefaultSingletonTraits<HWNDInfoMap> {
-};
-
-void NotifyHWNDCreation(const tracked_objects::Location& from_here, HWND hwnd) {
- HWNDInfoMap* birth_map = Singleton<HWNDInfoMap, HWNDBirthMapTrait>::get();
- HWNDInfoMap::iterator birth_iter = birth_map->find(hwnd);
- if (birth_iter != birth_map->end()) {
- birth_map->erase(birth_iter);
-
- // We have already seen this HWND, was it destroyed?
- HWNDInfoMap* death_map = Singleton<HWNDInfoMap, HWNDDeathMapTrait>::get();
- HWNDInfoMap::iterator death_iter = death_map->find(hwnd);
- if (death_iter == death_map->end()) {
- // We did not get a destruction notification. The code is probably not
- // calling NotifyHWNDDestruction for that HWND.
- NOTREACHED() << "Creation of HWND reported for already tracked HWND. The "
- "HWND destruction is probably not tracked properly. "
- "Fix it!";
- } else {
- death_map->erase(death_iter);
- }
- }
- birth_map->insert(std::pair<HWND, tracked_objects::Location>(hwnd,
- from_here));
-}
-
-void NotifyHWNDDestruction(const tracked_objects::Location& from_here,
- HWND hwnd) {
- HWNDInfoMap* death_map = Singleton<HWNDInfoMap, HWNDDeathMapTrait>::get();
- HWNDInfoMap::iterator death_iter = death_map->find(hwnd);
-
- HWNDInfoMap* birth_map = Singleton<HWNDInfoMap, HWNDBirthMapTrait>::get();
- HWNDInfoMap::iterator birth_iter = birth_map->find(hwnd);
-
- if (death_iter != death_map->end()) {
- std::string allocation, first_delete, second_delete;
- if (birth_iter != birth_map->end())
- birth_iter->second.Write(true, true, &allocation);
- death_iter->second.Write(true, true, &first_delete);
- from_here.Write(true, true, &second_delete);
- NOTREACHED() << "Double delete of an HWND. Please file a bug with info on "
- "how you got that assertion and the following information:\n"
- "Double delete of HWND 0x" << hwnd << "\n" <<
- "Allocated at " << allocation << "\n" <<
- "Deleted first at " << first_delete << "\n" <<
- "Deleted again at " << second_delete;
- death_map->erase(death_iter);
- }
-
- if (birth_iter == birth_map->end()) {
- NOTREACHED() << "Destruction of HWND reported for unknown HWND. The HWND "
- "construction is probably not tracked properly. Fix it!";
- }
- death_map->insert(std::pair<HWND, tracked_objects::Location>(hwnd,
- from_here));
-}
-
} // namespace win_util
#ifdef _MSC_VER
diff --git a/base/win_util.h b/base/win_util.h
index f6ce1c2..317c332 100644
--- a/base/win_util.h
+++ b/base/win_util.h
@@ -10,8 +10,6 @@
#include <string>
-#include "base/tracked.h"
-
namespace win_util {
// NOTE: Keep these in order so callers can do things like
@@ -104,22 +102,6 @@ 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__