summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-02-19 21:53:52 +0000
committerbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-02-19 21:53:52 +0000
commit6ad9e38d19aeef21882708deec510fd34516a82b (patch)
tree56f5b077ecbe88033fe6368ffbedcb3d99cffa62
parent5367dbc12dd614275b121dd239e97e606c197517 (diff)
downloadchromium_src-6ad9e38d19aeef21882708deec510fd34516a82b.zip
chromium_src-6ad9e38d19aeef21882708deec510fd34516a82b.tar.gz
chromium_src-6ad9e38d19aeef21882708deec510fd34516a82b.tar.bz2
Add a CHECK for NULL observers. I got a NULL pointer exception when notifying
on a notification, which is impossible to track down since I don't know who added it. Review URL: http://codereview.chromium.org/20502 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@10035 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/common/notification_service.cc7
1 files changed, 7 insertions, 0 deletions
diff --git a/chrome/common/notification_service.cc b/chrome/common/notification_service.cc
index 5b732df..5a9fa72 100644
--- a/chrome/common/notification_service.cc
+++ b/chrome/common/notification_service.cc
@@ -35,6 +35,13 @@ void NotificationService::AddObserver(NotificationObserver* observer,
const NotificationSource& source) {
DCHECK(type.value < NotificationType::NOTIFICATION_TYPE_COUNT);
+ // We have gotten some crashes where the observer pointer is NULL. The problem
+ // is that this happens when we actually execute a notification, so have no
+ // way of knowing who the bad observer was. We want to know when this happens
+ // in release mode so we know what code to blame the crash on (since this is
+ // guaranteed to crash later).
+ CHECK(observer);
+
NotificationObserverList* observer_list;
if (HasKey(observers_[type.value], source)) {
observer_list = observers_[type.value][source.map_key()];