OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/ui/webui/options/clear_browser_data_handler.h" | 5 #include "chrome/browser/ui/webui/options/clear_browser_data_handler.h" |
6 | 6 |
7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
8 #include "base/string16.h" | 8 #include "base/string16.h" |
9 #include "base/values.h" | 9 #include "base/values.h" |
10 #include "chrome/browser/browser_process.h" | 10 #include "chrome/browser/browser_process.h" |
11 #include "chrome/browser/prefs/pref_service.h" | 11 #include "chrome/browser/prefs/pref_service.h" |
12 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
13 #include "chrome/common/pref_names.h" | 13 #include "chrome/common/pref_names.h" |
14 #include "content/common/notification_details.h" | 14 #include "content/common/notification_details.h" |
15 #include "grit/chromium_strings.h" | 15 #include "grit/chromium_strings.h" |
16 #include "grit/generated_resources.h" | 16 #include "grit/generated_resources.h" |
17 #include "grit/locale_settings.h" | 17 #include "grit/locale_settings.h" |
18 #include "ui/base/l10n/l10n_util.h" | 18 #include "ui/base/l10n/l10n_util.h" |
19 | 19 |
20 ClearBrowserDataHandler::ClearBrowserDataHandler() : remover_(NULL) { | 20 ClearBrowserDataHandler::ClearBrowserDataHandler() : remover_(NULL) { |
21 } | 21 } |
22 | 22 |
23 ClearBrowserDataHandler::~ClearBrowserDataHandler() { | 23 ClearBrowserDataHandler::~ClearBrowserDataHandler() { |
24 if (remover_) { | 24 if (remover_) |
25 remover_->RemoveObserver(this); | 25 remover_->RemoveObserver(this); |
26 } | |
27 } | 26 } |
28 | 27 |
29 void ClearBrowserDataHandler::Initialize() { | 28 void ClearBrowserDataHandler::Initialize() { |
30 clear_plugin_lso_data_enabled_.Init(prefs::kClearPluginLSODataEnabled, | 29 clear_plugin_lso_data_enabled_.Init(prefs::kClearPluginLSODataEnabled, |
31 g_browser_process->local_state(), | 30 g_browser_process->local_state(), |
32 NULL); | 31 NULL); |
33 } | 32 } |
34 | 33 |
35 void ClearBrowserDataHandler::GetLocalizedValues( | 34 void ClearBrowserDataHandler::GetLocalizedValues( |
36 DictionaryValue* localized_strings) { | 35 DictionaryValue* localized_strings) { |
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
118 remove_mask |= BrowsingDataRemover::REMOVE_PASSWORDS; | 117 remove_mask |= BrowsingDataRemover::REMOVE_PASSWORDS; |
119 if (prefs->GetBoolean(prefs::kDeleteFormData)) | 118 if (prefs->GetBoolean(prefs::kDeleteFormData)) |
120 remove_mask |= BrowsingDataRemover::REMOVE_FORM_DATA; | 119 remove_mask |= BrowsingDataRemover::REMOVE_FORM_DATA; |
121 | 120 |
122 int period_selected = prefs->GetInteger(prefs::kDeleteTimePeriod); | 121 int period_selected = prefs->GetInteger(prefs::kDeleteTimePeriod); |
123 | 122 |
124 FundamentalValue state(true); | 123 FundamentalValue state(true); |
125 web_ui_->CallJavascriptFunction("ClearBrowserDataOverlay.setClearingState", | 124 web_ui_->CallJavascriptFunction("ClearBrowserDataOverlay.setClearingState", |
126 state); | 125 state); |
127 | 126 |
| 127 // If we are still observing a previous data remover, we need to stop |
| 128 // observing. |
| 129 if (remover_) |
| 130 remover_->RemoveObserver(this); |
| 131 |
128 // BrowsingDataRemover deletes itself when done. | 132 // BrowsingDataRemover deletes itself when done. |
129 remover_ = new BrowsingDataRemover(profile, | 133 remover_ = new BrowsingDataRemover(profile, |
130 static_cast<BrowsingDataRemover::TimePeriod>(period_selected), | 134 static_cast<BrowsingDataRemover::TimePeriod>(period_selected), |
131 base::Time()); | 135 base::Time()); |
132 remover_->AddObserver(this); | 136 remover_->AddObserver(this); |
133 remover_->Remove(remove_mask); | 137 remover_->Remove(remove_mask); |
134 } | 138 } |
135 | 139 |
136 void ClearBrowserDataHandler::OnBrowsingDataRemoverDone() { | 140 void ClearBrowserDataHandler::OnBrowsingDataRemoverDone() { |
137 // No need to remove ourselves as an observer as BrowsingDataRemover deletes | 141 // No need to remove ourselves as an observer as BrowsingDataRemover deletes |
138 // itself after we return. | 142 // itself after we return. |
139 remover_ = NULL; | 143 remover_ = NULL; |
140 DCHECK(web_ui_); | 144 DCHECK(web_ui_); |
141 web_ui_->CallJavascriptFunction("ClearBrowserDataOverlay.doneClearing"); | 145 web_ui_->CallJavascriptFunction("ClearBrowserDataOverlay.doneClearing"); |
142 } | 146 } |
OLD | NEW |