| Index: chrome/browser/history/history.cc
|
| ===================================================================
|
| --- chrome/browser/history/history.cc (revision 25782)
|
| +++ chrome/browser/history/history.cc (working copy)
|
| @@ -40,6 +40,7 @@
|
| #include "chrome/browser/history/history_types.h"
|
| #include "chrome/browser/history/in_memory_database.h"
|
| #include "chrome/browser/history/in_memory_history_backend.h"
|
| +#include "chrome/browser/history/visit_log.h"
|
| #include "chrome/browser/profile.h"
|
| #include "chrome/browser/visitedlink_master.h"
|
| #include "chrome/common/chrome_constants.h"
|
| @@ -53,8 +54,31 @@
|
| using base::Time;
|
| using history::HistoryBackend;
|
|
|
| -static const char* kHistoryThreadName = "Chrome_HistoryThread";
|
| +namespace {
|
|
|
| +class ChromeHistoryThread : public ChromeThread {
|
| + public:
|
| + ChromeHistoryThread() : ChromeThread(ChromeThread::HISTORY) {}
|
| + virtual ~ChromeHistoryThread() {
|
| + // We cannot rely on our base class to call Stop() since we want our
|
| + // CleanUp function to run.
|
| + Stop();
|
| + }
|
| + protected:
|
| + virtual void CleanUp() {
|
| + history::ClearVisitLog();
|
| + }
|
| + virtual void Run(MessageLoop* message_loop) {
|
| + // Allocate VisitLog on local stack so it will be saved in crash dump.
|
| + history::VisitLog visit_log;
|
| + history::InitVisitLog(&visit_log);
|
| + message_loop->Run();
|
| + history::ClearVisitLog();
|
| + }
|
| +};
|
| +
|
| +} // namespace
|
| +
|
| // Sends messages from the backend to us on the main thread. This must be a
|
| // separate class from the history service so that it can hold a reference to
|
| // the history service (otherwise we would have to manually AddRef and
|
| @@ -100,7 +124,7 @@
|
| const history::StarID HistoryService::kBookmarkBarID = 1;
|
|
|
| HistoryService::HistoryService()
|
| - : thread_(new base::Thread(kHistoryThreadName)),
|
| + : thread_(new ChromeHistoryThread()),
|
| profile_(NULL),
|
| backend_loaded_(false) {
|
| // Is NULL when running generate_profile.
|
| @@ -111,7 +135,7 @@
|
| }
|
|
|
| HistoryService::HistoryService(Profile* profile)
|
| - : thread_(new base::Thread(kHistoryThreadName)),
|
| + : thread_(new ChromeHistoryThread()),
|
| profile_(profile),
|
| backend_loaded_(false) {
|
| registrar_.Add(this, NotificationType::HISTORY_URLS_DELETED,
|
|
|