summaryrefslogtreecommitdiffstats
path: root/chrome/app
diff options
context:
space:
mode:
authornsylvain@google.com <nsylvain@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-07-31 18:26:01 +0000
committernsylvain@google.com <nsylvain@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-07-31 18:26:01 +0000
commitb3358a60841326bc3da7222191994e33135339ad (patch)
tree54b9d2ec310a9030eaefc2564547123f0f362a60 /chrome/app
parentdc36e9c53d3760bbdc4253b786c4686f4cf7a3ea (diff)
downloadchromium_src-b3358a60841326bc3da7222191994e33135339ad.zip
chromium_src-b3358a60841326bc3da7222191994e33135339ad.tar.gz
chromium_src-b3358a60841326bc3da7222191994e33135339ad.tar.bz2
We did not display "Chrome crashed, Do you want to restart chrome" when breakpad is not initialized. Now we register a exception filter all the time.
BUG:1302309 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@187 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/app')
-rw-r--r--chrome/app/breakpad.cc26
-rw-r--r--chrome/app/breakpad.h4
-rw-r--r--chrome/app/main.cc3
3 files changed, 30 insertions, 3 deletions
diff --git a/chrome/app/breakpad.cc b/chrome/app/breakpad.cc
index 6cbea27..26bafd7 100644
--- a/chrome/app/breakpad.cc
+++ b/chrome/app/breakpad.cc
@@ -108,8 +108,6 @@ const wchar_t kEnvShowRestart[] = L"CHROME_CRASHED";
const wchar_t kRtlLocaleDirection[] = L"RIGHT_TO_LEFT";
const wchar_t kLtrLocaleDirection[] = L"LEFT_TO_RIGHT";
-} // namespace
-
// This callback is executed when the browser process has crashed, after
// the crash dump has been created. We need to minimize the amount of work
// done here since we have potentially corrupted process. Our job is to
@@ -137,6 +135,23 @@ bool DumpDoneCallback(const wchar_t*, const wchar_t*, void*,
return true;
}
+// Previous unhandled filter. Will be called if not null when we
+// intercept a crash.
+LPTOP_LEVEL_EXCEPTION_FILTER previous_filter = NULL;
+
+// Exception filter used when breakpad is not enabled. We just display
+// the "Do you want to restart" message and then we call the previous filter.
+long WINAPI ChromeExceptionFilter(EXCEPTION_POINTERS* info) {
+ DumpDoneCallback(NULL, NULL, NULL, info, NULL, false);
+
+ if (previous_filter)
+ return previous_filter(info);
+
+ return EXCEPTION_EXECUTE_HANDLER;
+}
+
+} // namespace
+
// This function is executed by the child process that DumpDoneCallback()
// spawned and basically just shows the 'chrome has crashed' dialog if
// the CHROME_CRASHED environment variable is present.
@@ -221,9 +236,16 @@ unsigned __stdcall InitCrashReporterThread(void* param) {
return 0;
}
+void InitDefaultCrashCallback() {
+ previous_filter = SetUnhandledExceptionFilter(ChromeExceptionFilter);
+}
+
void InitCrashReporter(std::wstring dll_path) {
CommandLine command;
if (!command.HasSwitch(switches::kDisableBreakpad)) {
+ // Disable the message box for assertions.
+ _CrtSetReportMode(_CRT_ASSERT, 0);
+
// Query the custom_info now because if we do it in the thread it's going to
// fail in the sandbox. The thread will delete this object.
CrashReporterInfo* info = new CrashReporterInfo;
diff --git a/chrome/app/breakpad.h b/chrome/app/breakpad.h
index ad87567..2d0f9f8e 100644
--- a/chrome/app/breakpad.h
+++ b/chrome/app/breakpad.h
@@ -37,6 +37,10 @@
// or directly for the plugin and renderer process.
void InitCrashReporter(std::wstring dll_path);
+// Intercepts a crash but does not process it, just ask if we want to restart
+// the browser or not.
+void InitDefaultCrashCallback();
+
// Initializes the crash reporter in chrome.
unsigned __stdcall InitCrashReporterThread(void* param);
diff --git a/chrome/app/main.cc b/chrome/app/main.cc
index f309e17..cbcfdee 100644
--- a/chrome/app/main.cc
+++ b/chrome/app/main.cc
@@ -71,8 +71,9 @@ int APIENTRY wWinMain(HINSTANCE instance, HINSTANCE prev_instance,
// Initialize the crash reporter.
if (GoogleUpdateSettings::GetCollectStatsConsent()) {
- _CrtSetReportMode(_CRT_ASSERT, 0);
InitCrashReporter(client.GetDLLPath());
+ } else {
+ InitDefaultCrashCallback();
}
bool exit_now = false;