From 8f2dd91e3436b4872413baf0a7233a49aba0604a Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Wed, 13 Nov 2013 16:48:30 +0800 Subject: [PATCH] Setup breakpad in crash reporter. --- browser/crash_reporter_mac.mm | 58 ++++++++++++++++++++++++++++++----- 1 file changed, 50 insertions(+), 8 deletions(-) diff --git a/browser/crash_reporter_mac.mm b/browser/crash_reporter_mac.mm index 1fda81ae51f1..b5eff7172cf5 100644 --- a/browser/crash_reporter_mac.mm +++ b/browser/crash_reporter_mac.mm @@ -4,28 +4,70 @@ #include "browser/crash_reporter.h" -#import - +#include "base/logging.h" #include "base/strings/sys_string_conversions.h" +#include "common/atom_version.h" +#import "vendor/breakpad/src/client/apple/Framework/BreakpadDefines.h" +#import "vendor/breakpad/src/client/mac/Framework/Breakpad.h" namespace crash_reporter { +namespace { + +class ScopedCrashReporter { + public: + ScopedCrashReporter() { + NSMutableDictionary* parameters = + [NSMutableDictionary dictionaryWithCapacity:4]; + [parameters setValue:@"Atom-Shell" forKey:@BREAKPAD_PRODUCT]; + [parameters setValue:@"GitHub, Inc" forKey:@BREAKPAD_VENDOR]; + [parameters setValue:@"0" forKey:@BREAKPAD_REPORT_INTERVAL]; + [parameters setValue:@ATOM_VERSION_STRING forKey:@BREAKPAD_VERSION]; + // Use my server as /dev/null for now. + [parameters setValue:@"http://54.249.141.255" forKey:@BREAKPAD_URL]; + + breakpad_ = BreakpadCreate(parameters); + } + + ~ScopedCrashReporter() { if (breakpad_) BreakpadRelease(breakpad_); } + + void SetKey(const std::string& key, const std::string& value) { + BreakpadSetKeyValue(breakpad_, + base::SysUTF8ToNSString(key), + base::SysUTF8ToNSString(value)); + } + + static ScopedCrashReporter* Get() { + if (g_scoped_crash_reporter_ == NULL) + g_scoped_crash_reporter_ = new ScopedCrashReporter(); + return g_scoped_crash_reporter_; + } + + private: + BreakpadRef breakpad_; + + static ScopedCrashReporter* g_scoped_crash_reporter_; + + DISALLOW_COPY_AND_ASSIGN(ScopedCrashReporter); +}; + +ScopedCrashReporter* ScopedCrashReporter::g_scoped_crash_reporter_ = NULL; + +} // namespace + // static void CrashReporter::SetCompanyName(const std::string& name) { - BWQuincyManager *manager = [BWQuincyManager sharedQuincyManager]; - [manager setCompanyName:base::SysUTF8ToNSString(name)]; + ScopedCrashReporter::Get()->SetKey(BREAKPAD_VENDOR, name); } // static void CrashReporter::SetSubmissionURL(const std::string& url) { - BWQuincyManager *manager = [BWQuincyManager sharedQuincyManager]; - [manager setSubmissionURL:base::SysUTF8ToNSString(url)]; + ScopedCrashReporter::Get()->SetKey(BREAKPAD_URL, url); } // static void CrashReporter::SetAutoSubmit(bool yes) { - BWQuincyManager *manager = [BWQuincyManager sharedQuincyManager]; - [manager setAutoSubmitCrashReport:yes]; + ScopedCrashReporter::Get()->SetKey(BREAKPAD_SKIP_CONFIRM, yes ? "YES" : "NO"); } } // namespace crash_reporter