summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authorerg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2010-10-22 17:28:43 +0000
committererg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2010-10-22 17:28:43 +0000
commit38e0898607eea03649b7b07e9cf890af7dc33ac7 (patch)
tree6ac95fd496661a6e0718c349bba089144e0fef09 /chrome
parent2a9662e31f18f77b856487b7266c70ccede557e0 (diff)
downloadchromium_src-38e0898607eea03649b7b07e9cf890af7dc33ac7.zip
chromium_src-38e0898607eea03649b7b07e9cf890af7dc33ac7.tar.gz
chromium_src-38e0898607eea03649b7b07e9cf890af7dc33ac7.tar.bz2
FBTF: More dtor deinlining. (Can almost see the end!)
BUG=none TEST=compiles Review URL: http://codereview.chromium.org/3962004 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@63527 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/content_setting_bubble_model.cc15
-rw-r--r--chrome/browser/content_setting_bubble_model.h12
-rw-r--r--chrome/browser/file_path_watcher.cc19
-rw-r--r--chrome/browser/file_path_watcher.h10
-rw-r--r--chrome/browser/geolocation/device_data_provider.cc105
-rw-r--r--chrome/browser/geolocation/device_data_provider.h95
-rw-r--r--chrome/browser/gtk/options/simple_content_exceptions_window.cc2
-rw-r--r--chrome/browser/gtk/options/simple_content_exceptions_window.h2
-rw-r--r--chrome/browser/icon_manager.cc6
-rw-r--r--chrome/browser/icon_manager.h6
-rw-r--r--chrome/browser/in_process_webkit/indexed_db_callbacks.cc43
-rw-r--r--chrome/browser/in_process_webkit/indexed_db_callbacks.h34
-rw-r--r--chrome/browser/language_order_table_model.cc2
-rw-r--r--chrome/browser/language_order_table_model.h2
-rw-r--r--chrome/browser/parsers/metadata_parser_filebase.cc8
-rw-r--r--chrome/browser/parsers/metadata_parser_filebase.h4
-rw-r--r--chrome/browser/policy/config_dir_policy_provider.cc6
-rw-r--r--chrome/browser/policy/config_dir_policy_provider.h6
-rw-r--r--chrome/browser/policy/configuration_policy_pref_store.cc2
-rw-r--r--chrome/browser/policy/configuration_policy_pref_store.h2
-rw-r--r--chrome/browser/printing/print_dialog_cloud.cc20
-rw-r--r--chrome/browser/printing/print_dialog_cloud_internal.h14
-rw-r--r--chrome/browser/renderer_host/audio_renderer_host.cc9
-rw-r--r--chrome/browser/renderer_host/audio_renderer_host.h8
-rw-r--r--chrome/browser/renderer_host/buffered_resource_handler.cc2
-rw-r--r--chrome/browser/renderer_host/buffered_resource_handler.h26
-rw-r--r--chrome/browser/renderer_host/cross_site_resource_handler.cc2
-rw-r--r--chrome/browser/renderer_host/cross_site_resource_handler.h28
-rw-r--r--chrome/browser/renderer_host/database_dispatcher_host.cc2
-rw-r--r--chrome/browser/renderer_host/database_dispatcher_host.h3
-rw-r--r--chrome/browser/renderer_host/resource_request_details.cc54
-rw-r--r--chrome/browser/renderer_host/resource_request_details.h43
-rw-r--r--chrome/browser/renderer_host/save_file_resource_handler.cc2
-rw-r--r--chrome/browser/renderer_host/save_file_resource_handler.h27
-rw-r--r--chrome/browser/safe_browsing/safe_browsing_service.cc16
-rw-r--r--chrome/browser/safe_browsing/safe_browsing_service.h9
-rw-r--r--chrome/browser/sidebar/sidebar_manager.cc7
-rw-r--r--chrome/browser/sidebar/sidebar_manager.h17
-rw-r--r--chrome/browser/speech/endpointer/energy_endpointer_params.cc53
-rw-r--r--chrome/browser/speech/endpointer/energy_endpointer_params.h48
-rw-r--r--chrome/browser/speech/speech_recognition_request.cc2
-rw-r--r--chrome/browser/speech/speech_recognition_request.h2
-rw-r--r--chrome/browser/ssl/ssl_request_info.cc23
-rw-r--r--chrome/browser/ssl/ssl_request_info.h13
-rw-r--r--chrome/browser/sync/glue/autofill_change_processor.cc13
-rw-r--r--chrome/browser/sync/glue/autofill_change_processor.h14
-rw-r--r--chrome/browser/sync/glue/autofill_model_associator.cc30
-rw-r--r--chrome/browser/sync/glue/autofill_model_associator.h26
-rw-r--r--chrome/browser/sync/glue/extension_data.cc2
-rw-r--r--chrome/browser/sync/glue/extension_data.h2
-rw-r--r--chrome/browser/sync/glue/password_model_associator.cc2
-rw-r--r--chrome/browser/sync/glue/password_model_associator.h2
-rw-r--r--chrome/browser/sync/glue/password_model_worker.cc2
-rw-r--r--chrome/browser/sync/glue/password_model_worker.h1
-rw-r--r--chrome/browser/sync/glue/typed_url_model_associator.cc2
-rw-r--r--chrome/browser/sync/glue/typed_url_model_associator.h2
-rw-r--r--chrome/browser/webdata/autofill_change.cc36
-rw-r--r--chrome/browser/webdata/autofill_change.h22
-rw-r--r--chrome/browser/webdata/autofill_entry.cc28
-rw-r--r--chrome/browser/webdata/autofill_entry.h23
-rw-r--r--chrome/browser/worker_host/message_port_dispatcher.cc15
-rw-r--r--chrome/browser/worker_host/message_port_dispatcher.h17
-rw-r--r--chrome/chrome.gyp1
-rw-r--r--chrome/chrome_browser.gypi7
-rw-r--r--chrome/chrome_common.gypi3
-rw-r--r--chrome/common/dx_diag_node.cc9
-rw-r--r--chrome/common/dx_diag_node.h3
-rw-r--r--chrome/common/gpu_create_command_buffer_config.cc16
-rw-r--r--chrome/common/gpu_create_command_buffer_config.h12
-rw-r--r--chrome/gpu/gpu_video_decoder.cc11
-rw-r--r--chrome/gpu/gpu_video_decoder.h11
-rw-r--r--chrome/gpu/gpu_video_decoder_unittest.cc1
-rw-r--r--chrome/gpu/gpu_video_service.cc7
-rw-r--r--chrome/gpu/gpu_video_service.h5
-rw-r--r--chrome/renderer/extensions/bindings_utils.cc20
-rw-r--r--chrome/renderer/extensions/bindings_utils.h20
-rw-r--r--chrome/renderer/form_manager.cc6
-rw-r--r--chrome/renderer/form_manager.h6
-rw-r--r--chrome/renderer/gpu_video_decoder_host.cc2
-rw-r--r--chrome/renderer/gpu_video_decoder_host.h2
-rw-r--r--chrome/renderer/paint_aggregator.cc4
-rw-r--r--chrome/renderer/paint_aggregator.h10
-rw-r--r--chrome/renderer/pepper_devices.cc25
-rw-r--r--chrome/renderer/pepper_devices.h24
-rw-r--r--chrome/renderer/pepper_plugin_delegate_impl.cc2
-rw-r--r--chrome/renderer/pepper_plugin_delegate_impl.h2
-rw-r--r--chrome/renderer/user_script_slave.cc2
-rw-r--r--chrome/renderer/user_script_slave.h1
-rw-r--r--chrome/renderer/websharedworkerrepository_impl.cc4
-rw-r--r--chrome/renderer/websharedworkerrepository_impl.h3
-rw-r--r--chrome/service/cloud_print/print_system.cc36
-rw-r--r--chrome/service/cloud_print/print_system.h40
92 files changed, 901 insertions, 444 deletions
diff --git a/chrome/browser/content_setting_bubble_model.cc b/chrome/browser/content_setting_bubble_model.cc
index 65f1baa..2cc5d911 100644
--- a/chrome/browser/content_setting_bubble_model.cc
+++ b/chrome/browser/content_setting_bubble_model.cc
@@ -474,6 +474,21 @@ ContentSettingBubbleModel::ContentSettingBubbleModel(
ContentSettingBubbleModel::~ContentSettingBubbleModel() {
}
+ContentSettingBubbleModel::RadioGroup::RadioGroup() : default_item(0) {}
+
+ContentSettingBubbleModel::RadioGroup::~RadioGroup() {}
+
+ContentSettingBubbleModel::DomainList::DomainList() {}
+
+ContentSettingBubbleModel::DomainList::~DomainList() {}
+
+ContentSettingBubbleModel::BubbleContent::BubbleContent()
+ : load_plugins_link_enabled(false) {
+}
+
+ContentSettingBubbleModel::BubbleContent::~BubbleContent() {}
+
+
void ContentSettingBubbleModel::AddBlockedResource(
const std::string& resource_identifier) {
bubble_content_.resource_identifiers.insert(resource_identifier);
diff --git a/chrome/browser/content_setting_bubble_model.h b/chrome/browser/content_setting_bubble_model.h
index 97664d8..49af1b2 100644
--- a/chrome/browser/content_setting_bubble_model.h
+++ b/chrome/browser/content_setting_bubble_model.h
@@ -42,6 +42,9 @@ class ContentSettingBubbleModel : public NotificationObserver {
typedef std::vector<std::string> RadioItems;
struct RadioGroup {
+ RadioGroup();
+ ~RadioGroup();
+
GURL url;
std::string title;
RadioItems radio_items;
@@ -49,11 +52,17 @@ class ContentSettingBubbleModel : public NotificationObserver {
};
struct DomainList {
+ DomainList();
+ ~DomainList();
+
std::string title;
std::set<std::string> hosts;
};
struct BubbleContent {
+ BubbleContent();
+ ~BubbleContent();
+
std::string title;
PopupItems popup_items;
RadioGroup radio_group;
@@ -64,6 +73,9 @@ class ContentSettingBubbleModel : public NotificationObserver {
std::string info_link;
std::string load_plugins_link_title;
bool load_plugins_link_enabled;
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(BubbleContent);
};
const BubbleContent& bubble_content() const { return bubble_content_; }
diff --git a/chrome/browser/file_path_watcher.cc b/chrome/browser/file_path_watcher.cc
new file mode 100644
index 0000000..19aff7a
--- /dev/null
+++ b/chrome/browser/file_path_watcher.cc
@@ -0,0 +1,19 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// Cross platform methods for FilePathWatcher. See the various platform
+// specific implementaiton files, too.
+
+#include "chrome/browser/file_path_watcher.h"
+
+FilePathWatcher::~FilePathWatcher() {
+ impl_->Cancel();
+}
+
+bool FilePathWatcher::Watch(const FilePath& path,
+ Delegate* delegate) {
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE));
+ DCHECK(path.IsAbsolute());
+ return impl_->Watch(path, delegate);
+}
diff --git a/chrome/browser/file_path_watcher.h b/chrome/browser/file_path_watcher.h
index da123c6..51d25cf 100644
--- a/chrome/browser/file_path_watcher.h
+++ b/chrome/browser/file_path_watcher.h
@@ -33,17 +33,11 @@ class FilePathWatcher {
};
FilePathWatcher();
- ~FilePathWatcher() {
- impl_->Cancel();
- }
+ ~FilePathWatcher();
// Register interest in any changes on |path|. OnPathChanged will be called
// back for each change. Returns true on success.
- bool Watch(const FilePath& path, Delegate* delegate) WARN_UNUSED_RESULT {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE));
- DCHECK(path.IsAbsolute());
- return impl_->Watch(path, delegate);
- }
+ bool Watch(const FilePath& path, Delegate* delegate) WARN_UNUSED_RESULT;
// Used internally to encapsulate different members on different platforms.
class PlatformDelegate
diff --git a/chrome/browser/geolocation/device_data_provider.cc b/chrome/browser/geolocation/device_data_provider.cc
new file mode 100644
index 0000000..9fe592a
--- /dev/null
+++ b/chrome/browser/geolocation/device_data_provider.cc
@@ -0,0 +1,105 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/geolocation/device_data_provider.h"
+
+namespace {
+
+bool CellDataMatches(const CellData &data1, const CellData &data2) {
+ return data1.Matches(data2);
+}
+
+} // namespace
+
+CellData::CellData()
+ : cell_id(kint32min),
+ location_area_code(kint32min),
+ mobile_network_code(kint32min),
+ mobile_country_code(kint32min),
+ radio_signal_strength(kint32min),
+ timing_advance(kint32min) {
+}
+
+RadioData::RadioData()
+ : home_mobile_network_code(kint32min),
+ home_mobile_country_code(kint32min),
+ radio_type(RADIO_TYPE_UNKNOWN) {
+}
+
+RadioData::~RadioData() {}
+
+bool RadioData::Matches(const RadioData &other) const {
+ if (cell_data.size() != other.cell_data.size()) {
+ return false;
+ }
+ if (!std::equal(cell_data.begin(), cell_data.end(), other.cell_data.begin(),
+ CellDataMatches)) {
+ return false;
+ }
+ return device_id == other.device_id &&
+ home_mobile_network_code == other.home_mobile_network_code &&
+ home_mobile_country_code == other.home_mobile_country_code &&
+ radio_type == other.radio_type &&
+ carrier == other.carrier;
+}
+
+AccessPointData::AccessPointData()
+ : radio_signal_strength(kint32min),
+ channel(kint32min),
+ signal_to_noise(kint32min) {
+}
+
+AccessPointData::~AccessPointData() {}
+
+WifiData::WifiData() {}
+
+WifiData::~WifiData() {}
+
+bool WifiData::DiffersSignificantly(const WifiData& other) const {
+ // More than 4 or 50% of access points added or removed is significant.
+ static const size_t kMinChangedAccessPoints = 4;
+ const size_t min_ap_count =
+ std::min(access_point_data.size(), other.access_point_data.size());
+ const size_t max_ap_count =
+ std::max(access_point_data.size(), other.access_point_data.size());
+ const size_t difference_threadhold = std::min(kMinChangedAccessPoints,
+ min_ap_count / 2);
+ if (max_ap_count > min_ap_count + difference_threadhold)
+ return true;
+ // Compute size of interesction of old and new sets.
+ size_t num_common = 0;
+ for (AccessPointDataSet::const_iterator iter = access_point_data.begin();
+ iter != access_point_data.end();
+ iter++) {
+ if (other.access_point_data.find(*iter) !=
+ other.access_point_data.end()) {
+ ++num_common;
+ }
+ }
+ DCHECK(num_common <= min_ap_count);
+
+ // Test how many have changed.
+ return max_ap_count > num_common + difference_threadhold;
+}
+
+GatewayData::GatewayData() {}
+
+GatewayData::~GatewayData() {}
+
+bool GatewayData::DiffersSignificantly(const GatewayData& other) const {
+ // Any change is significant.
+ if (this->router_data.size() != other.router_data.size())
+ return true;
+ RouterDataSet::const_iterator iter1 = router_data.begin();
+ RouterDataSet::const_iterator iter2 = other.router_data.begin();
+ while (iter1 != router_data.end()) {
+ if (iter1->mac_address != iter2->mac_address) {
+ // There is a difference between the sets of routers.
+ return true;
+ }
+ ++iter1;
+ ++iter2;
+ }
+ return false;
+}
diff --git a/chrome/browser/geolocation/device_data_provider.h b/chrome/browser/geolocation/device_data_provider.h
index 9cd4390..b6a3882 100644
--- a/chrome/browser/geolocation/device_data_provider.h
+++ b/chrome/browser/geolocation/device_data_provider.h
@@ -44,13 +44,7 @@
// Cell radio data relating to a single cell tower.
struct CellData {
- CellData()
- : cell_id(kint32min),
- location_area_code(kint32min),
- mobile_network_code(kint32min),
- mobile_country_code(kint32min),
- radio_signal_strength(kint32min),
- timing_advance(kint32min) {}
+ CellData();
bool Matches(const CellData &other) const {
// Ignore radio_signal_strength when matching.
return cell_id == other.cell_id &&
@@ -70,10 +64,6 @@ struct CellData {
// meters.
};
-static bool CellDataMatches(const CellData &data1, const CellData &data2) {
- return data1.Matches(data2);
-}
-
enum RadioType {
RADIO_TYPE_UNKNOWN,
RADIO_TYPE_GSM,
@@ -83,24 +73,11 @@ enum RadioType {
// All data for the cell radio.
struct RadioData {
- RadioData()
- : home_mobile_network_code(kint32min),
- home_mobile_country_code(kint32min),
- radio_type(RADIO_TYPE_UNKNOWN) {}
- bool Matches(const RadioData &other) const {
- if (cell_data.size() != other.cell_data.size()) {
- return false;
- }
- if (!std::equal(cell_data.begin(), cell_data.end(), other.cell_data.begin(),
- CellDataMatches)) {
- return false;
- }
- return device_id == other.device_id &&
- home_mobile_network_code == other.home_mobile_network_code &&
- home_mobile_country_code == other.home_mobile_country_code &&
- radio_type == other.radio_type &&
- carrier == other.carrier;
- }
+ RadioData();
+ ~RadioData();
+
+ bool Matches(const RadioData &other) const;
+
// Determines whether a new set of radio data differs significantly from this.
bool DiffersSignificantly(const RadioData &other) const {
// This is required by MockDeviceDataProviderImpl.
@@ -113,15 +90,14 @@ struct RadioData {
int home_mobile_network_code; // For the device's home network.
int home_mobile_country_code; // For the device's home network.
RadioType radio_type; // Mobile radio type.
- string16 carrier; // Carrier name.
+ string16 carrier; // Carrier name.
};
// Wifi data relating to a single access point.
struct AccessPointData {
- AccessPointData()
- : radio_signal_strength(kint32min),
- channel(kint32min),
- signal_to_noise(kint32min) {}
+ AccessPointData();
+ ~AccessPointData();
+
// MAC address, formatted as per MacAddressAsString16.
string16 mac_address;
int radio_signal_strength; // Measured in dBm
@@ -141,33 +117,11 @@ struct AccessPointDataLess {
// All data for wifi.
struct WifiData {
- // Determines whether a new set of WiFi data differs significantly from this.
- bool DiffersSignificantly(const WifiData& other) const {
- // More than 4 or 50% of access points added or removed is significant.
- static const size_t kMinChangedAccessPoints = 4;
- const size_t min_ap_count =
- std::min(access_point_data.size(), other.access_point_data.size());
- const size_t max_ap_count =
- std::max(access_point_data.size(), other.access_point_data.size());
- const size_t difference_threadhold = std::min(kMinChangedAccessPoints,
- min_ap_count / 2);
- if (max_ap_count > min_ap_count + difference_threadhold)
- return true;
- // Compute size of interesction of old and new sets.
- size_t num_common = 0;
- for (AccessPointDataSet::const_iterator iter = access_point_data.begin();
- iter != access_point_data.end();
- iter++) {
- if (other.access_point_data.find(*iter) !=
- other.access_point_data.end()) {
- ++num_common;
- }
- }
- DCHECK(num_common <= min_ap_count);
+ WifiData();
+ ~WifiData();
- // Test how many have changed.
- return max_ap_count > num_common + difference_threadhold;
- }
+ // Determines whether a new set of WiFi data differs significantly from this.
+ bool DiffersSignificantly(const WifiData& other) const;
// Store access points as a set, sorted by MAC address. This allows quick
// comparison of sets for detecting changes and for caching.
@@ -177,7 +131,6 @@ struct WifiData {
// Gateway data relating to a single router.
struct RouterData {
- RouterData() {}
// MAC address, formatted as per MacAddressAsString16.
string16 mac_address;
};
@@ -193,24 +146,12 @@ struct RouterDataLess {
// All gateway data for routers.
struct GatewayData {
+ GatewayData();
+ ~GatewayData();
+
// Determines whether a new set of gateway data differs significantly
// from this.
- bool DiffersSignificantly(const GatewayData& other) const {
- // Any change is significant.
- if (this->router_data.size() != other.router_data.size())
- return true;
- RouterDataSet::const_iterator iter1 = router_data.begin();
- RouterDataSet::const_iterator iter2 = other.router_data.begin();
- while (iter1 != router_data.end()) {
- if (iter1->mac_address != iter2->mac_address) {
- // There is a difference between the sets of routers.
- return true;
- }
- ++iter1;
- ++iter2;
- }
- return false;
- }
+ bool DiffersSignificantly(const GatewayData& other) const;
// Store routers as a set, sorted by MAC address. This allows quick
// comparison of sets for detecting changes and for caching.
diff --git a/chrome/browser/gtk/options/simple_content_exceptions_window.cc b/chrome/browser/gtk/options/simple_content_exceptions_window.cc
index 68c211a..682cca1 100644
--- a/chrome/browser/gtk/options/simple_content_exceptions_window.cc
+++ b/chrome/browser/gtk/options/simple_content_exceptions_window.cc
@@ -153,6 +153,8 @@ SimpleContentExceptionsWindow::SimpleContentExceptionsWindow(
g_signal_connect(dialog_, "destroy", G_CALLBACK(OnWindowDestroyThunk), this);
}
+SimpleContentExceptionsWindow::~SimpleContentExceptionsWindow() {}
+
void SimpleContentExceptionsWindow::SetColumnValues(int row,
GtkTreeIter* iter) {
std::wstring hostname = model_->GetText(row, IDS_EXCEPTIONS_HOSTNAME_HEADER);
diff --git a/chrome/browser/gtk/options/simple_content_exceptions_window.h b/chrome/browser/gtk/options/simple_content_exceptions_window.h
index c18dab1..2d3b068 100644
--- a/chrome/browser/gtk/options/simple_content_exceptions_window.h
+++ b/chrome/browser/gtk/options/simple_content_exceptions_window.h
@@ -23,6 +23,8 @@ class SimpleContentExceptionsWindow
RemoveRowsTableModel* model,
int tile_message_id);
+ virtual ~SimpleContentExceptionsWindow();
+
// gtk_tree::TableAdapter::Delegate implementation:
virtual void SetColumnValues(int row, GtkTreeIter* iter);
virtual void OnAnyModelUpdateStart();
diff --git a/chrome/browser/icon_manager.cc b/chrome/browser/icon_manager.cc
index 98ff322..8f74ce4 100644
--- a/chrome/browser/icon_manager.cc
+++ b/chrome/browser/icon_manager.cc
@@ -10,6 +10,12 @@
#include "third_party/skia/include/core/SkBitmap.h"
#include "third_party/skia/include/core/SkCanvas.h"
+struct IconManager::ClientRequest {
+ scoped_refptr<IconRequest> request;
+ IconGroupID group;
+ IconLoader::IconSize size;
+};
+
IconManager::IconManager() {
}
diff --git a/chrome/browser/icon_manager.h b/chrome/browser/icon_manager.h
index 7ccd55a..210fa28 100644
--- a/chrome/browser/icon_manager.h
+++ b/chrome/browser/icon_manager.h
@@ -106,13 +106,9 @@ class IconManager : public IconLoader::Delegate,
IconMap icon_cache_;
typedef CancelableRequest<IconRequestCallback> IconRequest;
- typedef struct {
- scoped_refptr<IconRequest> request;
- IconGroupID group;
- IconLoader::IconSize size;
- } ClientRequest;
// Asynchronous requests that have not yet been completed.
+ struct ClientRequest;
typedef std::map<IconLoader*, ClientRequest> ClientRequests;
ClientRequests requests_;
diff --git a/chrome/browser/in_process_webkit/indexed_db_callbacks.cc b/chrome/browser/in_process_webkit/indexed_db_callbacks.cc
new file mode 100644
index 0000000..faaa933
--- /dev/null
+++ b/chrome/browser/in_process_webkit/indexed_db_callbacks.cc
@@ -0,0 +1,43 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/in_process_webkit/indexed_db_callbacks.h"
+
+IndexedDBCallbacksBase::IndexedDBCallbacksBase(
+ IndexedDBDispatcherHost* dispatcher_host,
+ int32 response_id)
+ : dispatcher_host_(dispatcher_host),
+ response_id_(response_id) {
+}
+
+IndexedDBCallbacksBase::~IndexedDBCallbacksBase() {}
+
+IndexedDBTransactionCallbacks::IndexedDBTransactionCallbacks(
+ IndexedDBDispatcherHost* dispatcher_host,
+ int transaction_id)
+ : dispatcher_host_(dispatcher_host),
+ transaction_id_(transaction_id) {
+}
+
+IndexedDBTransactionCallbacks::~IndexedDBTransactionCallbacks() {}
+
+void IndexedDBCallbacksBase::onError(const WebKit::WebIDBDatabaseError& error) {
+ dispatcher_host_->Send(new ViewMsg_IDBCallbacksError(
+ response_id_, error.code(), error.message()));
+}
+
+void IndexedDBTransactionCallbacks::onAbort() {
+ dispatcher_host_->Send(
+ new ViewMsg_IDBTransactionCallbacksAbort(transaction_id_));
+}
+
+void IndexedDBTransactionCallbacks::onComplete() {
+ dispatcher_host_->Send(
+ new ViewMsg_IDBTransactionCallbacksComplete(transaction_id_));
+}
+
+void IndexedDBTransactionCallbacks::onTimeout() {
+ dispatcher_host_->Send(
+ new ViewMsg_IDBTransactionCallbacksTimeout(transaction_id_));
+}
diff --git a/chrome/browser/in_process_webkit/indexed_db_callbacks.h b/chrome/browser/in_process_webkit/indexed_db_callbacks.h
index 1c6ed37..653e211 100644
--- a/chrome/browser/in_process_webkit/indexed_db_callbacks.h
+++ b/chrome/browser/in_process_webkit/indexed_db_callbacks.h
@@ -37,14 +37,12 @@ template <> struct WebIDBToMsgHelper<WebKit::WebIDBTransaction> {
// The code the following two classes share.
class IndexedDBCallbacksBase : public WebKit::WebIDBCallbacks {
public:
- IndexedDBCallbacksBase(
- IndexedDBDispatcherHost* dispatcher_host, int32 response_id)
- : dispatcher_host_(dispatcher_host), response_id_(response_id) { }
+ IndexedDBCallbacksBase(IndexedDBDispatcherHost* dispatcher_host,
+ int32 response_id);
- virtual void onError(const WebKit::WebIDBDatabaseError& error) {
- dispatcher_host_->Send(new ViewMsg_IDBCallbacksError(
- response_id_, error.code(), error.message()));
- }
+ virtual ~IndexedDBCallbacksBase();
+
+ virtual void onError(const WebKit::WebIDBDatabaseError& error);
protected:
IndexedDBDispatcherHost* dispatcher_host() const {
@@ -166,25 +164,15 @@ class IndexedDBTransactionCallbacks
: public WebKit::WebIDBTransactionCallbacks {
public:
IndexedDBTransactionCallbacks(IndexedDBDispatcherHost* dispatcher_host,
- int transaction_id)
- : dispatcher_host_(dispatcher_host),
- transaction_id_(transaction_id) {
- }
+ int transaction_id);
- virtual void onAbort() {
- dispatcher_host_->Send(
- new ViewMsg_IDBTransactionCallbacksAbort(transaction_id_));
- }
+ virtual ~IndexedDBTransactionCallbacks();
- virtual void onComplete() {
- dispatcher_host_->Send(
- new ViewMsg_IDBTransactionCallbacksComplete(transaction_id_));
- }
+ virtual void onAbort();
- virtual void onTimeout() {
- dispatcher_host_->Send(
- new ViewMsg_IDBTransactionCallbacksTimeout(transaction_id_));
- }
+ virtual void onComplete();
+
+ virtual void onTimeout();
private:
scoped_refptr<IndexedDBDispatcherHost> dispatcher_host_;
diff --git a/chrome/browser/language_order_table_model.cc b/chrome/browser/language_order_table_model.cc
index 0f3680b..c1a4103 100644
--- a/chrome/browser/language_order_table_model.cc
+++ b/chrome/browser/language_order_table_model.cc
@@ -16,6 +16,8 @@ LanguageOrderTableModel::LanguageOrderTableModel()
: observer_(NULL) {
}
+LanguageOrderTableModel::~LanguageOrderTableModel() {}
+
void LanguageOrderTableModel::SetAcceptLanguagesString(
const std::string& language_list) {
std::vector<std::string> languages_vector;
diff --git a/chrome/browser/language_order_table_model.h b/chrome/browser/language_order_table_model.h
index 4b11748..9cfdf4c 100644
--- a/chrome/browser/language_order_table_model.h
+++ b/chrome/browser/language_order_table_model.h
@@ -18,6 +18,8 @@ class LanguageOrderTableModel : public TableModel {
public:
LanguageOrderTableModel();
+ virtual ~LanguageOrderTableModel();
+
// Set Language List.
void SetAcceptLanguagesString(const std::string& language_list);
diff --git a/chrome/browser/parsers/metadata_parser_filebase.cc b/chrome/browser/parsers/metadata_parser_filebase.cc
index 0146f3f..123cb6f 100644
--- a/chrome/browser/parsers/metadata_parser_filebase.cc
+++ b/chrome/browser/parsers/metadata_parser_filebase.cc
@@ -9,10 +9,12 @@
#include "base/utf_string_conversions.h"
FileMetadataParser::FileMetadataParser(const FilePath& path)
- : MetadataParser(path) {
- path_ = path;
+ : MetadataParser(path),
+ path_(path) {
}
+FileMetadataParser::~FileMetadataParser() {}
+
bool FileMetadataParser::Parse() {
std::string value;
int64 size;
@@ -48,6 +50,8 @@ FileMetadataPropertyIterator::FileMetadataPropertyIterator(
it = properties_.begin();
}
+FileMetadataPropertyIterator::~FileMetadataPropertyIterator() {}
+
bool FileMetadataPropertyIterator::GetNext(std::string* key,
std::string* value) {
if (it == properties_.end()) {
diff --git a/chrome/browser/parsers/metadata_parser_filebase.h b/chrome/browser/parsers/metadata_parser_filebase.h
index 8b232a2..9ed5775 100644
--- a/chrome/browser/parsers/metadata_parser_filebase.h
+++ b/chrome/browser/parsers/metadata_parser_filebase.h
@@ -21,6 +21,8 @@ class FileMetadataParser : public MetadataParser {
public:
explicit FileMetadataParser(const FilePath& path);
+ virtual ~FileMetadataParser();
+
// Implementation of MetadataParser
virtual bool Parse();
virtual bool GetProperty(const std::string& key, std::string* value);
@@ -39,6 +41,8 @@ class FileMetadataPropertyIterator : public MetadataPropertyIterator {
public:
explicit FileMetadataPropertyIterator(PropertyMap& properties);
+ virtual ~FileMetadataPropertyIterator();
+
// Implementation of MetadataPropertyIterator
virtual bool GetNext(std::string* key, std::string* value);
virtual int Length();
diff --git a/chrome/browser/policy/config_dir_policy_provider.cc b/chrome/browser/policy/config_dir_policy_provider.cc
index 6fe7630..a3f3e04 100644
--- a/chrome/browser/policy/config_dir_policy_provider.cc
+++ b/chrome/browser/policy/config_dir_policy_provider.cc
@@ -44,6 +44,8 @@ PolicyDirLoader::PolicyDirLoader(
DCHECK(policy_.get());
}
+PolicyDirLoader::~PolicyDirLoader() {}
+
void PolicyDirLoader::Stop() {
if (!BrowserThread::CurrentlyOn(BrowserThread::FILE)) {
BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE,
@@ -205,6 +207,8 @@ void PolicyDirLoader::ReloadFromTask() {
// PolicyDirWatcher implementation:
+PolicyDirWatcher::PolicyDirWatcher() {}
+
void PolicyDirWatcher::Init(PolicyDirLoader* loader) {
// Initialization can happen early when the file thread is not yet available.
// So post a task to ourselves on the UI thread which will run after threading
@@ -215,6 +219,8 @@ void PolicyDirWatcher::Init(PolicyDirLoader* loader) {
scoped_refptr<PolicyDirLoader>(loader)));
}
+PolicyDirWatcher::~PolicyDirWatcher() {}
+
void PolicyDirWatcher::InitWatcher(
const scoped_refptr<PolicyDirLoader>& loader) {
if (!BrowserThread::CurrentlyOn(BrowserThread::FILE)) {
diff --git a/chrome/browser/policy/config_dir_policy_provider.h b/chrome/browser/policy/config_dir_policy_provider.h
index 3657944..055ce06 100644
--- a/chrome/browser/policy/config_dir_policy_provider.h
+++ b/chrome/browser/policy/config_dir_policy_provider.h
@@ -38,6 +38,8 @@ class PolicyDirLoader : public FilePathWatcher::Delegate {
int settle_interval_seconds,
int reload_interval_minutes);
+ virtual ~PolicyDirLoader();
+
// Stops any pending reload tasks.
void Stop();
@@ -118,7 +120,7 @@ class PolicyDirLoader : public FilePathWatcher::Delegate {
// initializing the watcher object on the file thread.
class PolicyDirWatcher : public base::RefCountedThreadSafe<PolicyDirWatcher> {
public:
- PolicyDirWatcher() {}
+ PolicyDirWatcher();
// Runs initialization. This is in a separate method since we need to post a
// task (which cannot be done from the constructor).
@@ -127,7 +129,7 @@ class PolicyDirWatcher : public base::RefCountedThreadSafe<PolicyDirWatcher> {
private:
// PolicyDirWatcher objects should only be deleted by RefCountedThreadSafe.
friend class base::RefCountedThreadSafe<PolicyDirWatcher>;
- ~PolicyDirWatcher() {}
+ virtual ~PolicyDirWatcher();
// Actually sets up the watch with the FilePathWatcher code.
void InitWatcher(const scoped_refptr<PolicyDirLoader>& loader);
diff --git a/chrome/browser/policy/configuration_policy_pref_store.cc b/chrome/browser/policy/configuration_policy_pref_store.cc
index 74c4e51..8ebd74c 100644
--- a/chrome/browser/policy/configuration_policy_pref_store.cc
+++ b/chrome/browser/policy/configuration_policy_pref_store.cc
@@ -271,6 +271,8 @@ ConfigurationPolicyPrefStore::ConfigurationPolicyPrefStore(
use_system_proxy_(false) {
}
+ConfigurationPolicyPrefStore::~ConfigurationPolicyPrefStore() {}
+
PrefStore::PrefReadError ConfigurationPolicyPrefStore::ReadPrefs() {
proxy_disabled_ = false;
proxy_configuration_specified_ = false;
diff --git a/chrome/browser/policy/configuration_policy_pref_store.h b/chrome/browser/policy/configuration_policy_pref_store.h
index 8f8167d..83ab847 100644
--- a/chrome/browser/policy/configuration_policy_pref_store.h
+++ b/chrome/browser/policy/configuration_policy_pref_store.h
@@ -26,7 +26,7 @@ class ConfigurationPolicyPrefStore : public PrefStore,
// The ConfigurationPolicyPrefStore does not take ownership of the
// passed-in |provider|.
explicit ConfigurationPolicyPrefStore(ConfigurationPolicyProvider* provider);
- virtual ~ConfigurationPolicyPrefStore() { }
+ virtual ~ConfigurationPolicyPrefStore();
// PrefStore methods:
virtual PrefReadError ReadPrefs();
diff --git a/chrome/browser/printing/print_dialog_cloud.cc b/chrome/browser/printing/print_dialog_cloud.cc
index 6fd43f4..3fdad4b 100644
--- a/chrome/browser/printing/print_dialog_cloud.cc
+++ b/chrome/browser/printing/print_dialog_cloud.cc
@@ -152,6 +152,14 @@ void CloudPrintDataSender::CancelPrintDataFile() {
helper_ = NULL;
}
+CloudPrintDataSender::CloudPrintDataSender(CloudPrintDataSenderHelper* helper,
+ const string16& print_job_title)
+ : helper_(helper),
+ print_job_title_(print_job_title) {
+}
+
+CloudPrintDataSender::~CloudPrintDataSender() {}
+
// Grab the raw PDF file contents and massage them into shape for
// sending to the dialog contents (and up to the cloud print server)
// by encoding it and prefixing it with the appropriate mime type.
@@ -205,6 +213,18 @@ void CloudPrintDataSender::SendPrintDataFile() {
}
+CloudPrintFlowHandler::CloudPrintFlowHandler(const FilePath& path_to_pdf,
+ const string16& print_job_title)
+ : path_to_pdf_(path_to_pdf),
+ print_job_title_(print_job_title) {
+}
+
+CloudPrintFlowHandler::~CloudPrintFlowHandler() {
+ // This will also cancel any task in flight.
+ CancelAnyRunningTask();
+}
+
+
void CloudPrintFlowHandler::SetDialogDelegate(
CloudPrintHtmlDialogDelegate* delegate) {
// Even if setting a new dom_ui, it means any previous task needs
diff --git a/chrome/browser/printing/print_dialog_cloud_internal.h b/chrome/browser/printing/print_dialog_cloud_internal.h
index c40f301..4148623 100644
--- a/chrome/browser/printing/print_dialog_cloud_internal.h
+++ b/chrome/browser/printing/print_dialog_cloud_internal.h
@@ -53,8 +53,7 @@ class CloudPrintDataSender
// The owner of this object is also expected to own and control the
// lifetime of the helper.
CloudPrintDataSender(CloudPrintDataSenderHelper* helper,
- const string16& print_job_title)
- : helper_(helper), print_job_title_(print_job_title) {}
+ const string16& print_job_title);
// Calls to read in the PDF file (on the FILE thread) then send that
// information to the dialog renderer (on the IO thread). We know
@@ -69,7 +68,7 @@ class CloudPrintDataSender
private:
friend class base::RefCountedThreadSafe<CloudPrintDataSender>;
- ~CloudPrintDataSender() {}
+ virtual ~CloudPrintDataSender();
Lock lock_;
CloudPrintDataSenderHelper* volatile helper_;
@@ -92,13 +91,8 @@ class CloudPrintFlowHandler : public DOMMessageHandler,
public NotificationObserver {
public:
explicit CloudPrintFlowHandler(const FilePath& path_to_pdf,
- const string16& print_job_title)
- : path_to_pdf_(path_to_pdf),
- print_job_title_(print_job_title) {}
- virtual ~CloudPrintFlowHandler() {
- // This will also cancel any task in flight.
- CancelAnyRunningTask();
- }
+ const string16& print_job_title);
+ virtual ~CloudPrintFlowHandler();
// DOMMessageHandler implementation.
virtual void RegisterMessages();
diff --git a/chrome/browser/renderer_host/audio_renderer_host.cc b/chrome/browser/renderer_host/audio_renderer_host.cc
index 0b594a0..e5b9b2b 100644
--- a/chrome/browser/renderer_host/audio_renderer_host.cc
+++ b/chrome/browser/renderer_host/audio_renderer_host.cc
@@ -67,6 +67,15 @@ static uint32 SelectHardwarePacketSize(AudioParameters params) {
return params.channels * samples * params.bits_per_sample / 8;
}
+AudioRendererHost::AudioEntry::AudioEntry()
+ : render_view_id(0),
+ stream_id(0),
+ pending_buffer_request(false),
+ pending_close(false) {
+}
+
+AudioRendererHost::AudioEntry::~AudioEntry() {}
+
///////////////////////////////////////////////////////////////////////////////
// AudioRendererHost implementations.
AudioRendererHost::AudioRendererHost()
diff --git a/chrome/browser/renderer_host/audio_renderer_host.h b/chrome/browser/renderer_host/audio_renderer_host.h
index 8ec3cd1..d2dfd59 100644
--- a/chrome/browser/renderer_host/audio_renderer_host.h
+++ b/chrome/browser/renderer_host/audio_renderer_host.h
@@ -83,12 +83,8 @@ class AudioRendererHost : public base::RefCountedThreadSafe<
typedef std::pair<int32, int> AudioEntryId;
struct AudioEntry {
- AudioEntry()
- : render_view_id(0),
- stream_id(0),
- pending_buffer_request(false),
- pending_close(false) {
- }
+ AudioEntry();
+ ~AudioEntry();
// The AudioOutputController that manages the audio stream.
scoped_refptr<media::AudioOutputController> controller;
diff --git a/chrome/browser/renderer_host/buffered_resource_handler.cc b/chrome/browser/renderer_host/buffered_resource_handler.cc
index a19d3c3..d534042 100644
--- a/chrome/browser/renderer_host/buffered_resource_handler.cc
+++ b/chrome/browser/renderer_host/buffered_resource_handler.cc
@@ -149,6 +149,8 @@ bool BufferedResourceHandler::OnReadCompleted(int request_id, int* bytes_read) {
return real_handler_->OnReadCompleted(request_id, bytes_read);
}
+BufferedResourceHandler::~BufferedResourceHandler() {}
+
bool BufferedResourceHandler::DelayResponse() {
std::string mime_type;
request_->GetMimeType(&mime_type);
diff --git a/chrome/browser/renderer_host/buffered_resource_handler.h b/chrome/browser/renderer_host/buffered_resource_handler.h
index 26bd7f8..69e64c5 100644
--- a/chrome/browser/renderer_host/buffered_resource_handler.h
+++ b/chrome/browser/renderer_host/buffered_resource_handler.h
@@ -22,21 +22,21 @@ class BufferedResourceHandler : public ResourceHandler {
URLRequest* request);
// ResourceHandler implementation:
- bool OnUploadProgress(int request_id, uint64 position, uint64 size);
- bool OnRequestRedirected(int request_id, const GURL& new_url,
- ResourceResponse* response, bool* defer);
- bool OnResponseStarted(int request_id, ResourceResponse* response);
- bool OnWillStart(int request_id, const GURL& url, bool* defer);
- bool OnWillRead(int request_id, net::IOBuffer** buf, int* buf_size,
- int min_size);
- bool OnReadCompleted(int request_id, int* bytes_read);
- bool OnResponseCompleted(int request_id,
- const URLRequestStatus& status,
- const std::string& security_info);
- void OnRequestClosed();
+ virtual bool OnUploadProgress(int request_id, uint64 position, uint64 size);
+ virtual bool OnRequestRedirected(int request_id, const GURL& new_url,
+ ResourceResponse* response, bool* defer);
+ virtual bool OnResponseStarted(int request_id, ResourceResponse* response);
+ virtual bool OnWillStart(int request_id, const GURL& url, bool* defer);
+ virtual bool OnWillRead(int request_id, net::IOBuffer** buf, int* buf_size,
+ int min_size);
+ virtual bool OnReadCompleted(int request_id, int* bytes_read);
+ virtual bool OnResponseCompleted(int request_id,
+ const URLRequestStatus& status,
+ const std::string& security_info);
+ virtual void OnRequestClosed();
private:
- ~BufferedResourceHandler() {}
+ virtual ~BufferedResourceHandler();
// Returns true if we should delay OnResponseStarted forwarding.
bool DelayResponse();
diff --git a/chrome/browser/renderer_host/cross_site_resource_handler.cc b/chrome/browser/renderer_host/cross_site_resource_handler.cc
index 3198e76..ddab0e7 100644
--- a/chrome/browser/renderer_host/cross_site_resource_handler.cc
+++ b/chrome/browser/renderer_host/cross_site_resource_handler.cc
@@ -175,6 +175,8 @@ void CrossSiteResourceHandler::ResumeResponse() {
}
}
+CrossSiteResourceHandler::~CrossSiteResourceHandler() {}
+
// Prepare to render the cross-site response in a new RenderViewHost, by
// telling the old RenderViewHost to run its onunload handler.
void CrossSiteResourceHandler::StartCrossSiteTransition(
diff --git a/chrome/browser/renderer_host/cross_site_resource_handler.h b/chrome/browser/renderer_host/cross_site_resource_handler.h
index aa731ca..33c1109 100644
--- a/chrome/browser/renderer_host/cross_site_resource_handler.h
+++ b/chrome/browser/renderer_host/cross_site_resource_handler.h
@@ -25,26 +25,26 @@ class CrossSiteResourceHandler : public ResourceHandler {
ResourceDispatcherHost* resource_dispatcher_host);
// ResourceHandler implementation:
- bool OnUploadProgress(int request_id, uint64 position, uint64 size);
- bool OnRequestRedirected(int request_id, const GURL& new_url,
- ResourceResponse* response, bool* defer);
- bool OnResponseStarted(int request_id,
- ResourceResponse* response);
- bool OnWillStart(int request_id, const GURL& url, bool* defer);
- bool OnWillRead(int request_id, net::IOBuffer** buf, int* buf_size,
- int min_size);
- bool OnReadCompleted(int request_id, int* bytes_read);
- bool OnResponseCompleted(int request_id,
- const URLRequestStatus& status,
- const std::string& security_info);
- void OnRequestClosed();
+ virtual bool OnUploadProgress(int request_id, uint64 position, uint64 size);
+ virtual bool OnRequestRedirected(int request_id, const GURL& new_url,
+ ResourceResponse* response, bool* defer);
+ virtual bool OnResponseStarted(int request_id,
+ ResourceResponse* response);
+ virtual bool OnWillStart(int request_id, const GURL& url, bool* defer);
+ virtual bool OnWillRead(int request_id, net::IOBuffer** buf, int* buf_size,
+ int min_size);
+ virtual bool OnReadCompleted(int request_id, int* bytes_read);
+ virtual bool OnResponseCompleted(int request_id,
+ const URLRequestStatus& status,
+ const std::string& security_info);
+ virtual void OnRequestClosed();
// We can now send the response to the new renderer, which will cause
// TabContents to swap in the new renderer and destroy the old one.
void ResumeResponse();
private:
- ~CrossSiteResourceHandler() {}
+ virtual ~CrossSiteResourceHandler();
// Prepare to render the cross-site response in a new RenderViewHost, by
// telling the old RenderViewHost to run its onunload handler.
diff --git a/chrome/browser/renderer_host/database_dispatcher_host.cc b/chrome/browser/renderer_host/database_dispatcher_host.cc
index 276ba75..11c5125 100644
--- a/chrome/browser/renderer_host/database_dispatcher_host.cc
+++ b/chrome/browser/renderer_host/database_dispatcher_host.cc
@@ -124,6 +124,8 @@ void DatabaseDispatcherHost::Send(IPC::Message* message) {
delete message;
}
+DatabaseDispatcherHost::~DatabaseDispatcherHost() {}
+
void DatabaseDispatcherHost::OnDatabaseOpenFile(const string16& vfs_file_name,
int desired_flags,
IPC::Message* reply_msg) {
diff --git a/chrome/browser/renderer_host/database_dispatcher_host.h b/chrome/browser/renderer_host/database_dispatcher_host.h
index 58b9b6e..000c0632 100644
--- a/chrome/browser/renderer_host/database_dispatcher_host.h
+++ b/chrome/browser/renderer_host/database_dispatcher_host.h
@@ -74,6 +74,9 @@ class DatabaseDispatcherHost
void Send(IPC::Message* message);
private:
+ friend class base::RefCountedThreadSafe<DatabaseDispatcherHost>;
+ virtual ~DatabaseDispatcherHost();
+
class PromptDelegate;
void AddObserver();
diff --git a/chrome/browser/renderer_host/resource_request_details.cc b/chrome/browser/renderer_host/resource_request_details.cc
new file mode 100644
index 0000000..20a255d
--- /dev/null
+++ b/chrome/browser/renderer_host/resource_request_details.cc
@@ -0,0 +1,54 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/renderer_host/resource_request_details.h"
+
+
+ResourceRequestDetails::ResourceRequestDetails(const URLRequest* request,
+ int cert_id)
+ : url_(request->url()),
+ original_url_(request->original_url()),
+ method_(request->method()),
+ referrer_(request->referrer()),
+ has_upload_(request->has_upload()),
+ load_flags_(request->load_flags()),
+ status_(request->status()),
+ ssl_cert_id_(cert_id),
+ ssl_cert_status_(request->ssl_info().cert_status) {
+ const ResourceDispatcherHostRequestInfo* info =
+ ResourceDispatcherHost::InfoForRequest(request);
+ DCHECK(info);
+ resource_type_ = info->resource_type();
+ frame_origin_ = info->frame_origin();
+ main_frame_origin_ = info->main_frame_origin();
+
+ // If request is from the worker process on behalf of a renderer, use
+ // the renderer process id, since it consumes the notification response
+ // such as ssl state etc.
+ const WorkerProcessHost::WorkerInstance* worker_instance =
+ WorkerService::GetInstance()->FindWorkerInstance(info->child_id());
+ if (worker_instance) {
+ DCHECK(!worker_instance->worker_document_set()->IsEmpty());
+ const WorkerDocumentSet::DocumentInfoSet& parents =
+ worker_instance->worker_document_set()->documents();
+ // TODO(atwilson): need to notify all associated renderers in the case
+ // of ssl state change (http://crbug.com/25357). For now, just notify
+ // the first one (works for dedicated workers and shared workers with
+ // a single process).
+ origin_child_id_ = parents.begin()->renderer_id();
+ } else {
+ origin_child_id_ = info->child_id();
+ }
+}
+
+ResourceRequestDetails::~ResourceRequestDetails() {}
+
+ResourceRedirectDetails::ResourceRedirectDetails(const URLRequest* request,
+ int cert_id,
+ const GURL& new_url)
+ : ResourceRequestDetails(request, cert_id),
+ new_url_(new_url) {
+}
+
+ResourceRedirectDetails::~ResourceRedirectDetails() {}
diff --git a/chrome/browser/renderer_host/resource_request_details.h b/chrome/browser/renderer_host/resource_request_details.h
index 6af9f85..36f3456 100644
--- a/chrome/browser/renderer_host/resource_request_details.h
+++ b/chrome/browser/renderer_host/resource_request_details.h
@@ -24,43 +24,9 @@ class URLRequest;
// Details about a resource request notification.
class ResourceRequestDetails {
public:
- ResourceRequestDetails(const URLRequest* request, int cert_id)
- : url_(request->url()),
- original_url_(request->original_url()),
- method_(request->method()),
- referrer_(request->referrer()),
- has_upload_(request->has_upload()),
- load_flags_(request->load_flags()),
- status_(request->status()),
- ssl_cert_id_(cert_id),
- ssl_cert_status_(request->ssl_info().cert_status) {
- const ResourceDispatcherHostRequestInfo* info =
- ResourceDispatcherHost::InfoForRequest(request);
- DCHECK(info);
- resource_type_ = info->resource_type();
- frame_origin_ = info->frame_origin();
- main_frame_origin_ = info->main_frame_origin();
+ ResourceRequestDetails(const URLRequest* request, int cert_id);
- // If request is from the worker process on behalf of a renderer, use
- // the renderer process id, since it consumes the notification response
- // such as ssl state etc.
- const WorkerProcessHost::WorkerInstance* worker_instance =
- WorkerService::GetInstance()->FindWorkerInstance(info->child_id());
- if (worker_instance) {
- DCHECK(!worker_instance->worker_document_set()->IsEmpty());
- const WorkerDocumentSet::DocumentInfoSet& parents =
- worker_instance->worker_document_set()->documents();
- // TODO(atwilson): need to notify all associated renderers in the case
- // of ssl state change (http://crbug.com/25357). For now, just notify
- // the first one (works for dedicated workers and shared workers with
- // a single process).
- origin_child_id_ = parents.begin()->renderer_id();
- } else {
- origin_child_id_ = info->child_id();
- }
- }
-
- virtual ~ResourceRequestDetails() {}
+ virtual ~ResourceRequestDetails();
const GURL& url() const { return url_; }
const GURL& original_url() const { return original_url_; }
@@ -97,9 +63,8 @@ class ResourceRedirectDetails : public ResourceRequestDetails {
public:
ResourceRedirectDetails(const URLRequest* request,
int cert_id,
- const GURL& new_url)
- : ResourceRequestDetails(request, cert_id),
- new_url_(new_url) {}
+ const GURL& new_url);
+ virtual ~ResourceRedirectDetails();
// The URL to which we are being redirected.
const GURL& new_url() const { return new_url_; }
diff --git a/chrome/browser/renderer_host/save_file_resource_handler.cc b/chrome/browser/renderer_host/save_file_resource_handler.cc
index 38f83bd..bc26ba5 100644
--- a/chrome/browser/renderer_host/save_file_resource_handler.cc
+++ b/chrome/browser/renderer_host/save_file_resource_handler.cc
@@ -115,3 +115,5 @@ void SaveFileResourceHandler::set_content_length(
const std::string& content_length) {
base::StringToInt64(content_length, &content_length_);
}
+
+SaveFileResourceHandler::~SaveFileResourceHandler() {}
diff --git a/chrome/browser/renderer_host/save_file_resource_handler.h b/chrome/browser/renderer_host/save_file_resource_handler.h
index ecd8a93..7475bef 100644
--- a/chrome/browser/renderer_host/save_file_resource_handler.h
+++ b/chrome/browser/renderer_host/save_file_resource_handler.h
@@ -21,32 +21,33 @@ class SaveFileResourceHandler : public ResourceHandler {
const GURL& url,
SaveFileManager* manager);
- bool OnUploadProgress(int request_id, uint64 position, uint64 size);
+ // ResourceHandler Implementation:
+ virtual bool OnUploadProgress(int request_id, uint64 position, uint64 size);
// Saves the redirected URL to final_url_, we need to use the original
// URL to match original request.
- bool OnRequestRedirected(int request_id, const GURL& url,
- ResourceResponse* response, bool* defer);
+ virtual bool OnRequestRedirected(int request_id, const GURL& url,
+ ResourceResponse* response, bool* defer);
// Sends the download creation information to the download thread.
- bool OnResponseStarted(int request_id, ResourceResponse* response);
+ virtual bool OnResponseStarted(int request_id, ResourceResponse* response);
// Pass-through implementation.
- bool OnWillStart(int request_id, const GURL& url, bool* defer);
+ virtual bool OnWillStart(int request_id, const GURL& url, bool* defer);
// Creates a new buffer, which will be handed to the download thread for file
// writing and deletion.
- bool OnWillRead(int request_id, net::IOBuffer** buf, int* buf_size,
- int min_size);
+ virtual bool OnWillRead(int request_id, net::IOBuffer** buf, int* buf_size,
+ int min_size);
// Passes the buffer to the download file writer.
- bool OnReadCompleted(int request_id, int* bytes_read);
+ virtual bool OnReadCompleted(int request_id, int* bytes_read);
- bool OnResponseCompleted(int request_id,
- const URLRequestStatus& status,
- const std::string& security_info);
+ virtual bool OnResponseCompleted(int request_id,
+ const URLRequestStatus& status,
+ const std::string& security_info);
- void OnRequestClosed();
+ virtual void OnRequestClosed();
// If the content-length header is not present (or contains something other
// than numbers), StringToInt64 returns 0, which indicates 'unknown size' and
@@ -58,7 +59,7 @@ class SaveFileResourceHandler : public ResourceHandler {
}
private:
- ~SaveFileResourceHandler() {}
+ virtual ~SaveFileResourceHandler();
int save_id_;
int render_process_id_;
diff --git a/chrome/browser/safe_browsing/safe_browsing_service.cc b/chrome/browser/safe_browsing/safe_browsing_service.cc
index 6f8619c..24f458c 100644
--- a/chrome/browser/safe_browsing/safe_browsing_service.cc
+++ b/chrome/browser/safe_browsing/safe_browsing_service.cc
@@ -57,6 +57,22 @@ struct SafeBrowsingService::WhiteListedEntry {
UrlCheckResult result;
};
+SafeBrowsingService::UnsafeResource::UnsafeResource()
+ : resource_type(ResourceType::MAIN_FRAME),
+ client(NULL),
+ render_process_host_id(-1),
+ render_view_id(-1) {
+}
+
+SafeBrowsingService::UnsafeResource::~UnsafeResource() {}
+
+SafeBrowsingService::SafeBrowsingCheck::SafeBrowsingCheck()
+ : client(NULL),
+ need_get_hash(false) {
+}
+
+SafeBrowsingService::SafeBrowsingCheck::~SafeBrowsingCheck() {}
+
SafeBrowsingService::SafeBrowsingService()
: database_(NULL),
protocol_manager_(NULL),
diff --git a/chrome/browser/safe_browsing/safe_browsing_service.h b/chrome/browser/safe_browsing/safe_browsing_service.h
index 050437a..acecf4e 100644
--- a/chrome/browser/safe_browsing/safe_browsing_service.h
+++ b/chrome/browser/safe_browsing/safe_browsing_service.h
@@ -59,6 +59,9 @@ class SafeBrowsingService
// Structure used to pass parameters between the IO and UI thread when
// interacting with the blocking page.
struct UnsafeResource {
+ UnsafeResource();
+ ~UnsafeResource();
+
GURL url;
GURL original_url;
ResourceType::Type resource_type;
@@ -70,6 +73,9 @@ class SafeBrowsingService
// Bundle of SafeBrowsing state for one URL check.
struct SafeBrowsingCheck {
+ SafeBrowsingCheck();
+ ~SafeBrowsingCheck();
+
GURL url;
Client* client;
bool need_get_hash;
@@ -77,6 +83,9 @@ class SafeBrowsingService
UrlCheckResult result;
std::vector<SBPrefix> prefix_hits;
std::vector<SBFullHashResult> full_hits;
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(SafeBrowsingCheck);
};
// Creates the safe browsing service. Need to initialize before using.
diff --git a/chrome/browser/sidebar/sidebar_manager.cc b/chrome/browser/sidebar/sidebar_manager.cc
index 62c46c14..e77041c 100644
--- a/chrome/browser/sidebar/sidebar_manager.cc
+++ b/chrome/browser/sidebar/sidebar_manager.cc
@@ -18,6 +18,13 @@
#include "chrome/common/pref_names.h"
#include "googleurl/src/gurl.h"
+struct SidebarManager::SidebarStateForTab {
+ // Sidebars linked to this tab.
+ ContentIdToSidebarHostMap content_id_to_sidebar_host;
+ // Content id of the currently active (expanded and visible) sidebar.
+ std::string active_content_id;
+};
+
// static
SidebarManager* SidebarManager::GetInstance() {
return g_browser_process->sidebar_manager();
diff --git a/chrome/browser/sidebar/sidebar_manager.h b/chrome/browser/sidebar/sidebar_manager.h
index a7fe8b1..6f2d20b 100644
--- a/chrome/browser/sidebar/sidebar_manager.h
+++ b/chrome/browser/sidebar/sidebar_manager.h
@@ -127,25 +127,18 @@ class SidebarManager : public NotificationObserver,
// This map stores sidebars linked to a particular tab. Sidebars are
// identified by their unique content id (string).
- typedef std::map<std::string, SidebarContainer*>
- ContentIdToSidebarHostMap;
+ typedef std::map<std::string, SidebarContainer*> ContentIdToSidebarHostMap;
+
// These two maps are for tracking dependencies between tabs and
// their SidebarContainers.
//
// SidebarManager start listening to SidebarContainers when they are put
// into these maps and removes them when they are closing.
- typedef struct {
- // Sidebars linked to this tab.
- ContentIdToSidebarHostMap content_id_to_sidebar_host;
- // Content id of the currently active (expanded and visible) sidebar.
- std::string active_content_id;
- } SidebarStateForTab;
- typedef std::map<TabContents*, SidebarStateForTab>
- TabToSidebarHostMap;
+ struct SidebarStateForTab;
+ typedef std::map<TabContents*, SidebarStateForTab> TabToSidebarHostMap;
TabToSidebarHostMap tab_to_sidebar_host_;
- typedef std::map<SidebarContainer*, TabContents*>
- SidebarHostToTabMap;
+ typedef std::map<SidebarContainer*, TabContents*> SidebarHostToTabMap;
SidebarHostToTabMap sidebar_host_to_tab_;
DISALLOW_COPY_AND_ASSIGN(SidebarManager);
diff --git a/chrome/browser/speech/endpointer/energy_endpointer_params.cc b/chrome/browser/speech/endpointer/energy_endpointer_params.cc
new file mode 100644
index 0000000..1ab044a
--- /dev/null
+++ b/chrome/browser/speech/endpointer/energy_endpointer_params.cc
@@ -0,0 +1,53 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/speech/endpointer/energy_endpointer_params.h"
+
+namespace speech_input {
+
+EnergyEndpointerParams::EnergyEndpointerParams() {
+ SetDefaults();
+}
+
+void EnergyEndpointerParams::SetDefaults() {
+ frame_period_ = 0.01f;
+ frame_duration_ = 0.01f;
+ endpoint_margin_ = 0.2f;
+ onset_window_ = 0.15f;
+ speech_on_window_ = 0.4f;
+ offset_window_ = 0.15f;
+ onset_detect_dur_ = 0.09f;
+ onset_confirm_dur_ = 0.075f;
+ on_maintain_dur_ = 0.10f;
+ offset_confirm_dur_ = 0.12f;
+ decision_threshold_ = 150.0f;
+ min_decision_threshold_ = 50.0f;
+ fast_update_dur_ = 0.2f;
+ sample_rate_ = 8000.0f;
+ min_fundamental_frequency_ = 57.143f;
+ max_fundamental_frequency_ = 400.0f;
+ contamination_rejection_period_ = 0.25f;
+}
+
+void EnergyEndpointerParams::operator=(const EnergyEndpointerParams& source) {
+ frame_period_ = source.frame_period();
+ frame_duration_ = source.frame_duration();
+ endpoint_margin_ = source.endpoint_margin();
+ onset_window_ = source.onset_window();
+ speech_on_window_ = source.speech_on_window();
+ offset_window_ = source.offset_window();
+ onset_detect_dur_ = source.onset_detect_dur();
+ onset_confirm_dur_ = source.onset_confirm_dur();
+ on_maintain_dur_ = source.on_maintain_dur();
+ offset_confirm_dur_ = source.offset_confirm_dur();
+ decision_threshold_ = source.decision_threshold();
+ min_decision_threshold_ = source.min_decision_threshold();
+ fast_update_dur_ = source.fast_update_dur();
+ sample_rate_ = source.sample_rate();
+ min_fundamental_frequency_ = source.min_fundamental_frequency();
+ max_fundamental_frequency_ = source.max_fundamental_frequency();
+ contamination_rejection_period_ = source.contamination_rejection_period();
+}
+
+} // namespace speech_input
diff --git a/chrome/browser/speech/endpointer/energy_endpointer_params.h b/chrome/browser/speech/endpointer/energy_endpointer_params.h
index c99ff99..86e44c9 100644
--- a/chrome/browser/speech/endpointer/energy_endpointer_params.h
+++ b/chrome/browser/speech/endpointer/energy_endpointer_params.h
@@ -12,49 +12,11 @@ namespace speech_input {
// Input parameters for the EnergyEndpointer class.
class EnergyEndpointerParams {
public:
- EnergyEndpointerParams() {
- SetDefaults();
- }
-
- void SetDefaults() {
- frame_period_ = 0.01f;
- frame_duration_ = 0.01f;
- endpoint_margin_ = 0.2f;
- onset_window_ = 0.15f;
- speech_on_window_ = 0.4f;
- offset_window_ = 0.15f;
- onset_detect_dur_ = 0.09f;
- onset_confirm_dur_ = 0.075f;
- on_maintain_dur_ = 0.10f;
- offset_confirm_dur_ = 0.12f;
- decision_threshold_ = 150.0f;
- min_decision_threshold_ = 50.0f;
- fast_update_dur_ = 0.2f;
- sample_rate_ = 8000.0f;
- min_fundamental_frequency_ = 57.143f;
- max_fundamental_frequency_ = 400.0f;
- contamination_rejection_period_ = 0.25f;
- }
-
- void operator=(const EnergyEndpointerParams& source) {
- frame_period_ = source.frame_period();
- frame_duration_ = source.frame_duration();
- endpoint_margin_ = source.endpoint_margin();
- onset_window_ = source.onset_window();
- speech_on_window_ = source.speech_on_window();
- offset_window_ = source.offset_window();
- onset_detect_dur_ = source.onset_detect_dur();
- onset_confirm_dur_ = source.onset_confirm_dur();
- on_maintain_dur_ = source.on_maintain_dur();
- offset_confirm_dur_ = source.offset_confirm_dur();
- decision_threshold_ = source.decision_threshold();
- min_decision_threshold_ = source.min_decision_threshold();
- fast_update_dur_ = source.fast_update_dur();
- sample_rate_ = source.sample_rate();
- min_fundamental_frequency_ = source.min_fundamental_frequency();
- max_fundamental_frequency_ = source.max_fundamental_frequency();
- contamination_rejection_period_ = source.contamination_rejection_period();
- }
+ EnergyEndpointerParams();
+
+ void SetDefaults();
+
+ void operator=(const EnergyEndpointerParams& source);
// Accessors and mutators
float frame_period() const { return frame_period_; }
diff --git a/chrome/browser/speech/speech_recognition_request.cc b/chrome/browser/speech/speech_recognition_request.cc
index 4da62ef..adf473f 100644
--- a/chrome/browser/speech/speech_recognition_request.cc
+++ b/chrome/browser/speech/speech_recognition_request.cc
@@ -96,6 +96,8 @@ SpeechRecognitionRequest::SpeechRecognitionRequest(
DCHECK(delegate);
}
+SpeechRecognitionRequest::~SpeechRecognitionRequest() {}
+
bool SpeechRecognitionRequest::Send(const std::string& content_type,
const std::string& audio_data) {
DCHECK(!url_fetcher_.get());
diff --git a/chrome/browser/speech/speech_recognition_request.h b/chrome/browser/speech/speech_recognition_request.h
index a8ffe2f..6c01983 100644
--- a/chrome/browser/speech/speech_recognition_request.h
+++ b/chrome/browser/speech/speech_recognition_request.h
@@ -38,6 +38,8 @@ class SpeechRecognitionRequest : public URLFetcher::Delegate {
const GURL& url,
Delegate* delegate);
+ virtual ~SpeechRecognitionRequest();
+
// Sends a new request with the given audio data, returns true if successful.
// The same object can be used to send multiple requests but only after the
// previous request has completed.
diff --git a/chrome/browser/ssl/ssl_request_info.cc b/chrome/browser/ssl/ssl_request_info.cc
new file mode 100644
index 0000000..7ba88b0
--- /dev/null
+++ b/chrome/browser/ssl/ssl_request_info.cc
@@ -0,0 +1,23 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/ssl/ssl_request_info.h"
+
+SSLRequestInfo::SSLRequestInfo(const GURL& url,
+ ResourceType::Type resource_type,
+ const std::string& frame_origin,
+ const std::string& main_frame_origin,
+ int child_id,
+ int ssl_cert_id,
+ int ssl_cert_status)
+ : url_(url),
+ resource_type_(resource_type),
+ frame_origin_(frame_origin),
+ main_frame_origin_(main_frame_origin),
+ child_id_(child_id),
+ ssl_cert_id_(ssl_cert_id),
+ ssl_cert_status_(ssl_cert_status) {
+}
+
+SSLRequestInfo::~SSLRequestInfo() {}
diff --git a/chrome/browser/ssl/ssl_request_info.h b/chrome/browser/ssl/ssl_request_info.h
index 2ce3e88..dc919cd 100644
--- a/chrome/browser/ssl/ssl_request_info.h
+++ b/chrome/browser/ssl/ssl_request_info.h
@@ -8,6 +8,7 @@
#include <string>
+#include "base/ref_counted.h"
#include "googleurl/src/gurl.h"
#include "webkit/glue/resource_type.h"
@@ -22,15 +23,7 @@ class SSLRequestInfo : public base::RefCounted<SSLRequestInfo> {
const std::string& main_frame_origin,
int child_id,
int ssl_cert_id,
- int ssl_cert_status)
- : url_(url),
- resource_type_(resource_type),
- frame_origin_(frame_origin),
- main_frame_origin_(main_frame_origin),
- child_id_(child_id),
- ssl_cert_id_(ssl_cert_id),
- ssl_cert_status_(ssl_cert_status) {
- }
+ int ssl_cert_status);
const GURL& url() const { return url_; }
ResourceType::Type resource_type() const { return resource_type_; }
@@ -43,7 +36,7 @@ class SSLRequestInfo : public base::RefCounted<SSLRequestInfo> {
private:
friend class base::RefCounted<SSLRequestInfo>;
- ~SSLRequestInfo() {}
+ virtual ~SSLRequestInfo();
GURL url_;
ResourceType::Type resource_type_;
diff --git a/chrome/browser/sync/glue/autofill_change_processor.cc b/chrome/browser/sync/glue/autofill_change_processor.cc
index c025e84..a2a8db4 100644
--- a/chrome/browser/sync/glue/autofill_change_processor.cc
+++ b/chrome/browser/sync/glue/autofill_change_processor.cc
@@ -20,6 +20,17 @@
namespace browser_sync {
+struct AutofillChangeProcessor::AutofillChangeRecord {
+ sync_api::SyncManager::ChangeRecord::Action action_;
+ int64 id_;
+ sync_pb::AutofillSpecifics autofill_;
+ AutofillChangeRecord(sync_api::SyncManager::ChangeRecord::Action action,
+ int64 id, const sync_pb::AutofillSpecifics& autofill)
+ : action_(action),
+ id_(id),
+ autofill_(autofill) { }
+};
+
AutofillChangeProcessor::AutofillChangeProcessor(
AutofillModelAssociator* model_associator,
WebDatabase* web_database,
@@ -38,6 +49,8 @@ AutofillChangeProcessor::AutofillChangeProcessor(
StartObserving();
}
+AutofillChangeProcessor::~AutofillChangeProcessor() {}
+
void AutofillChangeProcessor::Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details) {
diff --git a/chrome/browser/sync/glue/autofill_change_processor.h b/chrome/browser/sync/glue/autofill_change_processor.h
index 0680d0c..7a84520 100644
--- a/chrome/browser/sync/glue/autofill_change_processor.h
+++ b/chrome/browser/sync/glue/autofill_change_processor.h
@@ -40,7 +40,7 @@ class AutofillChangeProcessor : public ChangeProcessor,
WebDatabase* web_database,
PersonalDataManager* personal_data,
UnrecoverableErrorHandler* error_handler);
- virtual ~AutofillChangeProcessor() {}
+ virtual ~AutofillChangeProcessor();
// NotificationObserver implementation.
// WebDataService -> sync_api model change application.
@@ -73,17 +73,6 @@ class AutofillChangeProcessor : public ChangeProcessor,
virtual void StopImpl();
private:
- struct AutofillChangeRecord {
- sync_api::SyncManager::ChangeRecord::Action action_;
- int64 id_;
- sync_pb::AutofillSpecifics autofill_;
- AutofillChangeRecord(sync_api::SyncManager::ChangeRecord::Action action,
- int64 id, const sync_pb::AutofillSpecifics& autofill)
- : action_(action),
- id_(id),
- autofill_(autofill) { }
- };
-
void StartObserving();
void StopObserving();
@@ -170,6 +159,7 @@ class AutofillChangeProcessor : public ChangeProcessor,
// Record of changes from ApplyChangesFromSyncModel. These are then processed
// in CommitChangesFromSyncModel.
+ struct AutofillChangeRecord;
std::vector<AutofillChangeRecord> autofill_changes_;
DISALLOW_COPY_AND_ASSIGN(AutofillChangeProcessor);
diff --git a/chrome/browser/sync/glue/autofill_model_associator.cc b/chrome/browser/sync/glue/autofill_model_associator.cc
index 43914c2..b550ab5 100644
--- a/chrome/browser/sync/glue/autofill_model_associator.cc
+++ b/chrome/browser/sync/glue/autofill_model_associator.cc
@@ -30,6 +30,25 @@ const char kAutofillProfileNamespaceTag[] = "autofill_profile|";
static const int kMaxNumAttemptsToFindUniqueLabel = 100;
+struct AutofillModelAssociator::DataBundle {
+ std::set<AutofillKey> current_entries;
+ std::vector<AutofillEntry> new_entries;
+ std::set<string16> current_profiles;
+ std::vector<AutoFillProfile*> updated_profiles;
+ std::vector<AutoFillProfile*> new_profiles; // We own these pointers.
+ ~DataBundle() { STLDeleteElements(&new_profiles); }
+};
+
+AutofillModelAssociator::DoOptimisticRefreshTask::DoOptimisticRefreshTask(
+ PersonalDataManager* pdm) : pdm_(pdm) {}
+
+AutofillModelAssociator::DoOptimisticRefreshTask::~DoOptimisticRefreshTask() {}
+
+void AutofillModelAssociator::DoOptimisticRefreshTask::Run() {
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
+ pdm_->Refresh();
+}
+
AutofillModelAssociator::AutofillModelAssociator(
ProfileSyncService* sync_service,
WebDatabase* web_database,
@@ -396,6 +415,17 @@ void AutofillModelAssociator::AbortAssociation() {
abort_association_pending_ = true;
}
+const std::string*
+AutofillModelAssociator::GetChromeNodeFromSyncId(int64 sync_id) {
+ return NULL;
+}
+
+bool AutofillModelAssociator::InitSyncNodeFromChromeId(
+ std::string node_id,
+ sync_api::BaseNode* sync_node) {
+ return false;
+}
+
int64 AutofillModelAssociator::GetSyncIdFromChromeId(
const std::string autofill) {
AutofillToSyncIdMap::const_iterator iter = id_map_.find(autofill);
diff --git a/chrome/browser/sync/glue/autofill_model_associator.h b/chrome/browser/sync/glue/autofill_model_associator.h
index f0dbe1a..d4e5363 100644
--- a/chrome/browser/sync/glue/autofill_model_associator.h
+++ b/chrome/browser/sync/glue/autofill_model_associator.h
@@ -15,7 +15,6 @@
#include "base/lock.h"
#include "base/ref_counted.h"
#include "chrome/browser/autofill/personal_data_manager.h"
-#include "chrome/browser/browser_thread.h"
#include "chrome/browser/sync/engine/syncapi.h"
#include "chrome/browser/sync/glue/model_associator.h"
#include "chrome/browser/sync/protocol/autofill_specifics.pb.h"
@@ -56,11 +55,9 @@ class AutofillModelAssociator
// PersonalDataManager living on the UI thread that it needs to refresh.
class DoOptimisticRefreshTask : public Task {
public:
- explicit DoOptimisticRefreshTask(PersonalDataManager* pdm) : pdm_(pdm) {}
- virtual void Run() {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
- pdm_->Refresh();
- }
+ explicit DoOptimisticRefreshTask(PersonalDataManager* pdm);
+ virtual ~DoOptimisticRefreshTask();
+ virtual void Run();
private:
scoped_refptr<PersonalDataManager> pdm_;
};
@@ -81,15 +78,11 @@ class AutofillModelAssociator
virtual void AbortAssociation();
// Not implemented.
- virtual const std::string* GetChromeNodeFromSyncId(int64 sync_id) {
- return NULL;
- }
+ virtual const std::string* GetChromeNodeFromSyncId(int64 sync_id);
// Not implemented.
virtual bool InitSyncNodeFromChromeId(std::string node_id,
- sync_api::BaseNode* sync_node) {
- return false;
- }
+ sync_api::BaseNode* sync_node);
// Returns the sync id for the given autofill name, or sync_api::kInvalidId
// if the autofill name is not associated to any sync id.
@@ -137,14 +130,7 @@ class AutofillModelAssociator
// A convenience wrapper of a bunch of state we pass around while associating
// models, and send to the WebDatabase for persistence.
- struct DataBundle {
- std::set<AutofillKey> current_entries;
- std::vector<AutofillEntry> new_entries;
- std::set<string16> current_profiles;
- std::vector<AutoFillProfile*> updated_profiles;
- std::vector<AutoFillProfile*> new_profiles; // We own these pointers.
- ~DataBundle() { STLDeleteElements(&new_profiles); }
- };
+ struct DataBundle;
// Helper to query WebDatabase for the current autofill state.
bool LoadAutofillData(std::vector<AutofillEntry>* entries,
diff --git a/chrome/browser/sync/glue/extension_data.cc b/chrome/browser/sync/glue/extension_data.cc
index eb4fea6..c62c362 100644
--- a/chrome/browser/sync/glue/extension_data.cc
+++ b/chrome/browser/sync/glue/extension_data.cc
@@ -19,6 +19,8 @@ ExtensionData ExtensionData::FromData(
return extension_data;
}
+ExtensionData::~ExtensionData() {}
+
const sync_pb::ExtensionSpecifics& ExtensionData::merged_data() const {
DcheckIsExtensionSpecificsValid(merged_data_);
return merged_data_;
diff --git a/chrome/browser/sync/glue/extension_data.h b/chrome/browser/sync/glue/extension_data.h
index 67951b9..73316de 100644
--- a/chrome/browser/sync/glue/extension_data.h
+++ b/chrome/browser/sync/glue/extension_data.h
@@ -28,6 +28,8 @@ class ExtensionData {
static ExtensionData FromData(
Source source, const sync_pb::ExtensionSpecifics& data);
+ ~ExtensionData();
+
// Implicit copy constructor and assignment operator welcome.
// Returns the version of the data that all sources should
diff --git a/chrome/browser/sync/glue/password_model_associator.cc b/chrome/browser/sync/glue/password_model_associator.cc
index 7d33a0e..f9ab890 100644
--- a/chrome/browser/sync/glue/password_model_associator.cc
+++ b/chrome/browser/sync/glue/password_model_associator.cc
@@ -37,6 +37,8 @@ PasswordModelAssociator::PasswordModelAssociator(
#endif
}
+PasswordModelAssociator::~PasswordModelAssociator() {}
+
bool PasswordModelAssociator::AssociateModels() {
DCHECK(expected_loop_ == MessageLoop::current());
{
diff --git a/chrome/browser/sync/glue/password_model_associator.h b/chrome/browser/sync/glue/password_model_associator.h
index 096c3af..22c81ba 100644
--- a/chrome/browser/sync/glue/password_model_associator.h
+++ b/chrome/browser/sync/glue/password_model_associator.h
@@ -52,7 +52,7 @@ class PasswordModelAssociator
static syncable::ModelType model_type() { return syncable::PASSWORDS; }
PasswordModelAssociator(ProfileSyncService* sync_service,
PasswordStore* password_store);
- virtual ~PasswordModelAssociator() { }
+ virtual ~PasswordModelAssociator();
// PerDataTypeAssociatorInterface implementation.
//
diff --git a/chrome/browser/sync/glue/password_model_worker.cc b/chrome/browser/sync/glue/password_model_worker.cc
index 9c5b0d6..f832ac1 100644
--- a/chrome/browser/sync/glue/password_model_worker.cc
+++ b/chrome/browser/sync/glue/password_model_worker.cc
@@ -19,6 +19,8 @@ PasswordModelWorker::PasswordModelWorker(PasswordStore* password_store)
DCHECK(password_store);
}
+PasswordModelWorker::~PasswordModelWorker() {}
+
void PasswordModelWorker::DoWorkAndWaitUntilDone(Callback0::Type* work) {
WaitableEvent done(false, false);
password_store_->ScheduleTask(
diff --git a/chrome/browser/sync/glue/password_model_worker.h b/chrome/browser/sync/glue/password_model_worker.h
index cd55c79..cd16874 100644
--- a/chrome/browser/sync/glue/password_model_worker.h
+++ b/chrome/browser/sync/glue/password_model_worker.h
@@ -26,6 +26,7 @@ namespace browser_sync {
class PasswordModelWorker : public browser_sync::ModelSafeWorker {
public:
explicit PasswordModelWorker(PasswordStore* password_store);
+ virtual ~PasswordModelWorker();
// ModelSafeWorker implementation. Called on syncapi SyncerThread.
void DoWorkAndWaitUntilDone(Callback0::Type* work);
diff --git a/chrome/browser/sync/glue/typed_url_model_associator.cc b/chrome/browser/sync/glue/typed_url_model_associator.cc
index dc9cc3a..ad15629 100644
--- a/chrome/browser/sync/glue/typed_url_model_associator.cc
+++ b/chrome/browser/sync/glue/typed_url_model_associator.cc
@@ -29,6 +29,8 @@ TypedUrlModelAssociator::TypedUrlModelAssociator(
DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI));
}
+TypedUrlModelAssociator::~TypedUrlModelAssociator() {}
+
bool TypedUrlModelAssociator::AssociateModels() {
VLOG(1) << "Associating TypedUrl Models";
DCHECK(expected_loop_ == MessageLoop::current());
diff --git a/chrome/browser/sync/glue/typed_url_model_associator.h b/chrome/browser/sync/glue/typed_url_model_associator.h
index e894100..a07bae9 100644
--- a/chrome/browser/sync/glue/typed_url_model_associator.h
+++ b/chrome/browser/sync/glue/typed_url_model_associator.h
@@ -57,7 +57,7 @@ class TypedUrlModelAssociator
static syncable::ModelType model_type() { return syncable::TYPED_URLS; }
TypedUrlModelAssociator(ProfileSyncService* sync_service,
history::HistoryBackend* history_backend);
- virtual ~TypedUrlModelAssociator() { }
+ virtual ~TypedUrlModelAssociator();
// PerDataTypeAssociatorInterface implementation.
//
diff --git a/chrome/browser/webdata/autofill_change.cc b/chrome/browser/webdata/autofill_change.cc
new file mode 100644
index 0000000..7d51c0e
--- /dev/null
+++ b/chrome/browser/webdata/autofill_change.cc
@@ -0,0 +1,36 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/webdata/autofill_change.h"
+
+AutofillProfileChange::AutofillProfileChange(Type t,
+ string16 k,
+ const AutoFillProfile* p,
+ const string16& pre_update_label)
+ : GenericAutofillChange<string16>(t, k),
+ profile_(p),
+ pre_update_label_(pre_update_label) {
+}
+
+AutofillProfileChange::~AutofillProfileChange() {}
+
+bool AutofillProfileChange::operator==(
+ const AutofillProfileChange& change) const {
+ if (type() != change.type() || key() != change.key())
+ return false;
+ if (type() == REMOVE)
+ return true;
+ // TODO(dhollowa): Replace with |AutoFillProfile::Compare|.
+ // http://crbug.com/58813
+ if (*profile() != *change.profile())
+ return false;
+ return type() == ADD || pre_update_label_ == change.pre_update_label();
+}
+
+AutofillCreditCardChange::AutofillCreditCardChange(Type t,
+ string16 k,
+ const CreditCard* card)
+ : GenericAutofillChange<string16>(t, k), credit_card_(card) {}
+
+AutofillCreditCardChange::~AutofillCreditCardChange() {}
diff --git a/chrome/browser/webdata/autofill_change.h b/chrome/browser/webdata/autofill_change.h
index 11723d3..73c9c79 100644
--- a/chrome/browser/webdata/autofill_change.h
+++ b/chrome/browser/webdata/autofill_change.h
@@ -52,23 +52,13 @@ class AutofillProfileChange : public GenericAutofillChange<string16> {
// If t == REMOVE, |p| should be NULL. |pre_update_label| only applies to
// UPDATE changes.
AutofillProfileChange(Type t, string16 k, const AutoFillProfile* p,
- const string16& pre_update_label)
- : GenericAutofillChange<string16>(t, k), profile_(p),
- pre_update_label_(pre_update_label) {}
+ const string16& pre_update_label);
+ virtual ~AutofillProfileChange();
const AutoFillProfile* profile() const { return profile_; }
const string16& pre_update_label() const { return pre_update_label_; }
- bool operator==(const AutofillProfileChange& change) const {
- if (type() != change.type() || key() != change.key())
- return false;
- if (type() == REMOVE)
- return true;
- // TODO(dhollowa): Replace with |AutoFillProfile::Compare|.
- // http://crbug.com/58813
- if (*profile() != *change.profile())
- return false;
- return type() == ADD || pre_update_label_ == change.pre_update_label();
- }
+ bool operator==(const AutofillProfileChange& change) const;
+
private:
const AutoFillProfile* profile_; // Unowned pointer, can be NULL.
const string16 pre_update_label_;
@@ -77,8 +67,8 @@ class AutofillProfileChange : public GenericAutofillChange<string16> {
class AutofillCreditCardChange : public GenericAutofillChange<string16> {
public:
// If t == REMOVE, |card| should be NULL.
- AutofillCreditCardChange(Type t, string16 k, const CreditCard* card)
- : GenericAutofillChange<string16>(t, k), credit_card_(card) {}
+ AutofillCreditCardChange(Type t, string16 k, const CreditCard* card);
+ virtual ~AutofillCreditCardChange();
const CreditCard* credit_card() const { return credit_card_; }
bool operator==(const AutofillCreditCardChange& change) const {
diff --git a/chrome/browser/webdata/autofill_entry.cc b/chrome/browser/webdata/autofill_entry.cc
index d0f8913..31bc406 100644
--- a/chrome/browser/webdata/autofill_entry.cc
+++ b/chrome/browser/webdata/autofill_entry.cc
@@ -4,6 +4,26 @@
#include <set>
#include "chrome/browser/webdata/autofill_entry.h"
+#include "base/utf_string_conversions.h"
+
+AutofillKey::AutofillKey() {}
+
+AutofillKey::AutofillKey(const string16& name, const string16& value)
+ : name_(name),
+ value_(value) {
+}
+
+AutofillKey::AutofillKey(const char* name, const char* value)
+ : name_(UTF8ToUTF16(name)),
+ value_(UTF8ToUTF16(value)) {
+}
+
+AutofillKey::AutofillKey(const AutofillKey& key)
+ : name_(key.name()),
+ value_(key.value()) {
+}
+
+AutofillKey::~AutofillKey() {}
bool AutofillKey::operator==(const AutofillKey& key) const {
return name_ == key.name() && value_ == key.value();
@@ -20,6 +40,14 @@ bool AutofillKey::operator<(const AutofillKey& key) const {
}
}
+AutofillEntry::AutofillEntry(const AutofillKey& key,
+ const std::vector<base::Time>& timestamps)
+ : key_(key),
+ timestamps_(timestamps) {
+}
+
+AutofillEntry::~AutofillEntry() {}
+
bool AutofillEntry::operator==(const AutofillEntry& entry) const {
if (!(key_ == entry.key()))
return false;
diff --git a/chrome/browser/webdata/autofill_entry.h b/chrome/browser/webdata/autofill_entry.h
index 4917b29..7aa9139 100644
--- a/chrome/browser/webdata/autofill_entry.h
+++ b/chrome/browser/webdata/autofill_entry.h
@@ -9,21 +9,15 @@
#include <vector>
#include "base/string16.h"
#include "base/time.h"
-#include "base/utf_string_conversions.h"
class AutofillKey {
public:
- AutofillKey() {}
- AutofillKey(const string16& name, const string16& value)
- : name_(name),
- value_(value) {}
- AutofillKey(const char* name, const char* value)
- : name_(UTF8ToUTF16(name)),
- value_(UTF8ToUTF16(value)) {}
- AutofillKey(const AutofillKey& key)
- : name_(key.name()),
- value_(key.value()) {}
- virtual ~AutofillKey() {}
+ AutofillKey();
+ AutofillKey(const string16& name, const string16& value);
+ AutofillKey(const char* name, const char* value);
+ AutofillKey(const AutofillKey& key);
+ virtual ~AutofillKey();
+
const string16& name() const { return name_; }
const string16& value() const { return value_; }
@@ -38,9 +32,8 @@ class AutofillKey {
class AutofillEntry {
public:
AutofillEntry(const AutofillKey& key,
- const std::vector<base::Time>& timestamps)
- : key_(key),
- timestamps_(timestamps) {}
+ const std::vector<base::Time>& timestamps);
+ ~AutofillEntry();
const AutofillKey& key() const { return key_; }
const std::vector<base::Time>& timestamps() const { return timestamps_; }
diff --git a/chrome/browser/worker_host/message_port_dispatcher.cc b/chrome/browser/worker_host/message_port_dispatcher.cc
index edd4a94..49c87a09 100644
--- a/chrome/browser/worker_host/message_port_dispatcher.cc
+++ b/chrome/browser/worker_host/message_port_dispatcher.cc
@@ -12,6 +12,21 @@
#include "chrome/common/notification_service.h"
#include "chrome/common/worker_messages.h"
+struct MessagePortDispatcher::MessagePort {
+ // sender and route_id are what we need to send messages to the port.
+ IPC::Message::Sender* sender;
+ int route_id;
+ // A function pointer to generate a new route id for the sender above.
+ // Owned by "sender" above, so don't delete.
+ CallbackWithReturnValue<int>::Type* next_routing_id;
+ // A globally unique id for this message port.
+ int message_port_id;
+ // The globally unique id of the entangled message port.
+ int entangled_message_port_id;
+ // If true, all messages to this message port are queued and not delivered.
+ bool queue_messages;
+ QueuedMessages queued_messages;
+};
MessagePortDispatcher* MessagePortDispatcher::GetInstance() {
return Singleton<MessagePortDispatcher>::get();
diff --git a/chrome/browser/worker_host/message_port_dispatcher.h b/chrome/browser/worker_host/message_port_dispatcher.h
index b8f7021..566416b 100644
--- a/chrome/browser/worker_host/message_port_dispatcher.h
+++ b/chrome/browser/worker_host/message_port_dispatcher.h
@@ -74,22 +74,7 @@ class MessagePortDispatcher : public NotificationObserver {
// verify that the message port id exists.
void Erase(int message_port_id);
- struct MessagePort {
- // sender and route_id are what we need to send messages to the port.
- IPC::Message::Sender* sender;
- int route_id;
- // A function pointer to generate a new route id for the sender above.
- // Owned by "sender" above, so don't delete.
- CallbackWithReturnValue<int>::Type* next_routing_id;
- // A globally unique id for this message port.
- int message_port_id;
- // The globally unique id of the entangled message port.
- int entangled_message_port_id;
- // If true, all messages to this message port are queued and not delivered.
- bool queue_messages;
- QueuedMessages queued_messages;
- };
-
+ struct MessagePort;
typedef std::map<int, MessagePort> MessagePorts;
MessagePorts message_ports_;
diff --git a/chrome/chrome.gyp b/chrome/chrome.gyp
index 91a4636..b9a30e8 100644
--- a/chrome/chrome.gyp
+++ b/chrome/chrome.gyp
@@ -1134,6 +1134,7 @@
'service/cloud_print/job_status_updater.cc',
'service/cloud_print/job_status_updater.h',
'service/cloud_print/print_system_dummy.cc',
+ 'service/cloud_print/print_system.cc',
'service/cloud_print/print_system.h',
'service/cloud_print/printer_job_handler.cc',
'service/cloud_print/printer_job_handler.h',
diff --git a/chrome/chrome_browser.gypi b/chrome/chrome_browser.gypi
index 20e50d6..d9f8e78 100644
--- a/chrome/chrome_browser.gypi
+++ b/chrome/chrome_browser.gypi
@@ -1619,6 +1619,7 @@
'browser/fav_icon_helper.h',
'browser/favicon_service.cc',
'browser/favicon_service.h',
+ 'browser/file_path_watcher.cc',
'browser/file_path_watcher.h',
'browser/file_path_watcher_inotify.cc',
'browser/file_path_watcher_mac.cc',
@@ -1651,6 +1652,7 @@
'browser/geolocation/core_location_data_provider_mac.mm',
'browser/geolocation/core_location_provider_mac.h',
'browser/geolocation/core_location_provider_mac.mm',
+ 'browser/geolocation/device_data_provider.cc',
'browser/geolocation/device_data_provider.h',
'browser/geolocation/empty_device_data_provider.cc',
'browser/geolocation/empty_device_data_provider.h',
@@ -2094,6 +2096,7 @@
'browser/in_process_webkit/dom_storage_dispatcher_host.h',
'browser/in_process_webkit/dom_storage_namespace.cc',
'browser/in_process_webkit/dom_storage_namespace.h',
+ 'browser/in_process_webkit/indexed_db_callbacks.cc',
'browser/in_process_webkit/indexed_db_callbacks.h',
'browser/in_process_webkit/indexed_db_context.cc',
'browser/in_process_webkit/indexed_db_context.h',
@@ -2535,6 +2538,7 @@
'browser/renderer_host/resource_message_filter_win.cc',
'browser/renderer_host/resource_queue.cc',
'browser/renderer_host/resource_queue.h',
+ 'browser/renderer_host/resource_request_details.cc',
'browser/renderer_host/resource_request_details.h',
'browser/renderer_host/safe_browsing_resource_handler.cc',
'browser/renderer_host/safe_browsing_resource_handler.h',
@@ -2656,6 +2660,7 @@
'browser/speech/endpointer/endpointer.h',
'browser/speech/endpointer/energy_endpointer.cc',
'browser/speech/endpointer/energy_endpointer.h',
+ 'browser/speech/endpointer/energy_endpointer_params.cc',
'browser/speech/endpointer/energy_endpointer_params.h',
'browser/speech/speech_input_bubble.h',
'browser/speech/speech_input_bubble.cc',
@@ -2699,6 +2704,7 @@
'browser/ssl/ssl_policy.h',
'browser/ssl/ssl_policy_backend.cc',
'browser/ssl/ssl_policy_backend.h',
+ 'browser/ssl/ssl_request_info.cc',
'browser/ssl/ssl_request_info.h',
'browser/ssl_client_certificate_selector.h',
'browser/status_bubble.h',
@@ -3271,6 +3277,7 @@
'browser/visitedlink_master.h',
'browser/visitedlink_event_listener.cc',
'browser/visitedlink_event_listener.h',
+ 'browser/webdata/autofill_change.cc',
'browser/webdata/autofill_change.h',
'browser/webdata/autofill_entry.cc',
'browser/webdata/autofill_entry.h',
diff --git a/chrome/chrome_common.gypi b/chrome/chrome_common.gypi
index 463752c..e7970de 100644
--- a/chrome/chrome_common.gypi
+++ b/chrome/chrome_common.gypi
@@ -53,6 +53,7 @@
'common/devtools_messages.cc',
'common/devtools_messages.h',
'common/devtools_messages_internal.h',
+ 'common/dx_diag_node.cc',
'common/dx_diag_node.h',
'common/file_system/webfilesystem_callback_dispatcher.cc',
'common/file_system/webfilesystem_callback_dispatcher.h',
@@ -64,6 +65,8 @@
'common/font_descriptor_mac.mm',
'common/geoposition.cc',
'common/geoposition.h',
+ 'common/gpu_create_command_buffer_config.cc',
+ 'common/gpu_create_command_buffer_config.h',
'common/gpu_info.h',
'common/gpu_info.cc',
'common/gpu_messages.cc',
diff --git a/chrome/common/dx_diag_node.cc b/chrome/common/dx_diag_node.cc
new file mode 100644
index 0000000..85beb5b
--- /dev/null
+++ b/chrome/common/dx_diag_node.cc
@@ -0,0 +1,9 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/common/dx_diag_node.h"
+
+DxDiagNode::DxDiagNode() {}
+
+DxDiagNode::~DxDiagNode() {}
diff --git a/chrome/common/dx_diag_node.h b/chrome/common/dx_diag_node.h
index 9f20d92..6522213 100644
--- a/chrome/common/dx_diag_node.h
+++ b/chrome/common/dx_diag_node.h
@@ -12,6 +12,9 @@
#include <string>
struct DxDiagNode {
+ DxDiagNode();
+ ~DxDiagNode();
+
std::map<std::string, std::string> values;
std::map<std::string, DxDiagNode> children;
};
diff --git a/chrome/common/gpu_create_command_buffer_config.cc b/chrome/common/gpu_create_command_buffer_config.cc
new file mode 100644
index 0000000..e8ab9d7
--- /dev/null
+++ b/chrome/common/gpu_create_command_buffer_config.cc
@@ -0,0 +1,16 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/common/gpu_create_command_buffer_config.h"
+
+GPUCreateCommandBufferConfig::GPUCreateCommandBufferConfig() {}
+
+GPUCreateCommandBufferConfig::GPUCreateCommandBufferConfig(
+ const std::string& _allowed_extensions,
+ const std::vector<int>& _attribs)
+ : allowed_extensions(_allowed_extensions),
+ attribs(_attribs) {
+}
+
+GPUCreateCommandBufferConfig::~GPUCreateCommandBufferConfig() {}
diff --git a/chrome/common/gpu_create_command_buffer_config.h b/chrome/common/gpu_create_command_buffer_config.h
index 8a2525f..0cb217a 100644
--- a/chrome/common/gpu_create_command_buffer_config.h
+++ b/chrome/common/gpu_create_command_buffer_config.h
@@ -11,14 +11,12 @@
// Parameters passed when initializing a GPU channel.
struct GPUCreateCommandBufferConfig {
- GPUCreateCommandBufferConfig() { }
+ GPUCreateCommandBufferConfig();
- GPUCreateCommandBufferConfig(
- const std::string& _allowed_extensions,
- const std::vector<int>& _attribs)
- : allowed_extensions(_allowed_extensions),
- attribs(_attribs) {
- }
+ GPUCreateCommandBufferConfig(const std::string& _allowed_extensions,
+ const std::vector<int>& _attribs);
+
+ ~GPUCreateCommandBufferConfig();
std::string allowed_extensions;
std::vector<int> attribs;
diff --git a/chrome/gpu/gpu_video_decoder.cc b/chrome/gpu/gpu_video_decoder.cc
index 6c90df5..b998149 100644
--- a/chrome/gpu/gpu_video_decoder.cc
+++ b/chrome/gpu/gpu_video_decoder.cc
@@ -20,6 +20,15 @@
#include <d3d9.h>
#endif
+struct GpuVideoDecoder::PendingAllocation {
+ size_t n;
+ size_t width;
+ size_t height;
+ media::VideoFrame::Format format;
+ std::vector<scoped_refptr<media::VideoFrame> >* frames;
+ Task* task;
+};
+
void GpuVideoDecoder::OnChannelConnected(int32 peer_pid) {
}
@@ -251,6 +260,8 @@ GpuVideoDecoder::GpuVideoDecoder(
#endif
}
+GpuVideoDecoder::~GpuVideoDecoder() {}
+
void GpuVideoDecoder::OnInitialize(const GpuVideoDecoderInitParam& param) {
// TODO(jiesun): codec id should come from |param|.
config_.codec = media::kCodecH264;
diff --git a/chrome/gpu/gpu_video_decoder.h b/chrome/gpu/gpu_video_decoder.h
index 9a339e1..25885c8 100644
--- a/chrome/gpu/gpu_video_decoder.h
+++ b/chrome/gpu/gpu_video_decoder.h
@@ -97,7 +97,7 @@ class GpuVideoDecoder
IPC::Message::Sender* sender,
base::ProcessHandle handle,
gpu::gles2::GLES2Decoder* decoder);
- virtual ~GpuVideoDecoder() {}
+ virtual ~GpuVideoDecoder();
// IPC::Channel::Listener implementation.
virtual void OnChannelConnected(int32 peer_pid);
@@ -130,14 +130,7 @@ class GpuVideoDecoder
void SetGpuVideoDevice(GpuVideoDevice* device);
private:
- struct PendingAllocation {
- size_t n;
- size_t width;
- size_t height;
- media::VideoFrame::Format format;
- std::vector<scoped_refptr<media::VideoFrame> >* frames;
- Task* task;
- };
+ struct PendingAllocation;
int32 decoder_host_id() { return decoder_host_id_; }
diff --git a/chrome/gpu/gpu_video_decoder_unittest.cc b/chrome/gpu/gpu_video_decoder_unittest.cc
index 30f1664..b1ea751 100644
--- a/chrome/gpu/gpu_video_decoder_unittest.cc
+++ b/chrome/gpu/gpu_video_decoder_unittest.cc
@@ -2,6 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#include "base/message_loop.h"
#include "base/process.h"
#include "chrome/common/gpu_messages.h"
#include "chrome/gpu/gpu_video_decoder.h"
diff --git a/chrome/gpu/gpu_video_service.cc b/chrome/gpu/gpu_video_service.cc
index 2ef32e8..03025b8 100644
--- a/chrome/gpu/gpu_video_service.cc
+++ b/chrome/gpu/gpu_video_service.cc
@@ -7,10 +7,17 @@
#include "chrome/gpu/gpu_video_decoder.h"
#include "chrome/gpu/gpu_video_service.h"
+struct GpuVideoService::GpuVideoDecoderInfo {
+ scoped_refptr<GpuVideoDecoder> decoder;
+ GpuChannel* channel;
+};
+
+
GpuVideoService::GpuVideoService() {
// TODO(jiesun): move this time consuming stuff out of here.
IntializeGpuVideoService();
}
+
GpuVideoService::~GpuVideoService() {
// TODO(jiesun): move this time consuming stuff out of here.
UnintializeGpuVideoService();
diff --git a/chrome/gpu/gpu_video_service.h b/chrome/gpu/gpu_video_service.h
index a2c090e..e6af444 100644
--- a/chrome/gpu/gpu_video_service.h
+++ b/chrome/gpu/gpu_video_service.h
@@ -32,10 +32,7 @@ class GpuVideoService : public IPC::Channel::Listener,
int32 decoder_id);
private:
- struct GpuVideoDecoderInfo {
- scoped_refptr<GpuVideoDecoder> decoder;
- GpuChannel* channel;
- };
+ struct GpuVideoDecoderInfo;
GpuVideoService();
virtual ~GpuVideoService();
diff --git a/chrome/renderer/extensions/bindings_utils.cc b/chrome/renderer/extensions/bindings_utils.cc
index 2ddbefa..83ddeee 100644
--- a/chrome/renderer/extensions/bindings_utils.cc
+++ b/chrome/renderer/extensions/bindings_utils.cc
@@ -56,6 +56,19 @@ v8::Handle<v8::Value> ExtensionBase::GetChromeHidden(
return hidden;
}
+ContextInfo::ContextInfo(v8::Persistent<v8::Context> context,
+ const std::string& extension_id,
+ WebKit::WebFrame* parent_frame,
+ RenderView* render_view)
+ : context(context),
+ extension_id(extension_id),
+ parent_frame(parent_frame),
+ render_view(render_view),
+ num_connected_events(0) {
+}
+
+ContextInfo::~ContextInfo() {}
+
ContextList& GetContexts() {
return Singleton<SingletonData>::get()->contexts;
}
@@ -87,6 +100,13 @@ ContextInfo* GetInfoForCurrentContext() {
return context_iter->get();
}
+PendingRequest::PendingRequest(v8::Persistent<v8::Context> context,
+ const std::string& name)
+ : context(context), name(name) {
+}
+
+PendingRequest::~PendingRequest() {}
+
ContextList::iterator FindContext(v8::Handle<v8::Context> context) {
ContextList& all_contexts = GetContexts();
diff --git a/chrome/renderer/extensions/bindings_utils.h b/chrome/renderer/extensions/bindings_utils.h
index b269ad1..97973a9 100644
--- a/chrome/renderer/extensions/bindings_utils.h
+++ b/chrome/renderer/extensions/bindings_utils.h
@@ -67,6 +67,12 @@ const char* GetStringResource() {
// Contains information about a single javascript context.
struct ContextInfo {
+ ContextInfo(v8::Persistent<v8::Context> context,
+ const std::string& extension_id,
+ WebKit::WebFrame* parent_frame,
+ RenderView* render_view);
+ ~ContextInfo();
+
v8::Persistent<v8::Context> context;
std::string extension_id; // empty if the context is not an extension
@@ -85,14 +91,6 @@ struct ContextInfo {
// A count of the number of events that are listening in this context. When
// this is zero, |context| will be a weak handle.
int num_connected_events;
-
- ContextInfo(v8::Persistent<v8::Context> context,
- const std::string& extension_id,
- WebKit::WebFrame* parent_frame,
- RenderView* render_view)
- : context(context), extension_id(extension_id),
- parent_frame(parent_frame), render_view(render_view),
- num_connected_events(0) {}
};
typedef std::list< linked_ptr<ContextInfo> > ContextList;
@@ -113,9 +111,9 @@ ContextInfo* GetInfoForCurrentContext();
// Contains info relevant to a pending API request.
struct PendingRequest {
public :
- PendingRequest(v8::Persistent<v8::Context> context, const std::string& name)
- : context(context), name(name) {
- }
+ PendingRequest(v8::Persistent<v8::Context> context, const std::string& name);
+ ~PendingRequest();
+
v8::Persistent<v8::Context> context;
std::string name;
};
diff --git a/chrome/renderer/form_manager.cc b/chrome/renderer/form_manager.cc
index 9c49fd6..851eea4 100644
--- a/chrome/renderer/form_manager.cc
+++ b/chrome/renderer/form_manager.cc
@@ -237,6 +237,12 @@ void GetOptionStringsFromElement(WebFormControlElement element,
} // namespace
+struct FormManager::FormElement {
+ WebKit::WebFormElement form_element;
+ std::vector<WebKit::WebFormControlElement> control_elements;
+ std::vector<string16> control_values;
+};
+
FormManager::FormManager() {
}
diff --git a/chrome/renderer/form_manager.h b/chrome/renderer/form_manager.h
index a8643d9..3e4b834 100644
--- a/chrome/renderer/form_manager.h
+++ b/chrome/renderer/form_manager.h
@@ -115,11 +115,7 @@ class FormManager {
// Stores the WebFormElement and the form control elements for a form.
// Original form values are stored so when we clear a form we can reset
// "select-one" values to their original state.
- struct FormElement {
- WebKit::WebFormElement form_element;
- std::vector<WebKit::WebFormControlElement> control_elements;
- std::vector<string16> control_values;
- };
+ struct FormElement;
// Type for cache of FormElement objects.
typedef std::vector<FormElement*> FormElementList;
diff --git a/chrome/renderer/gpu_video_decoder_host.cc b/chrome/renderer/gpu_video_decoder_host.cc
index bf6c79f..44599f3 100644
--- a/chrome/renderer/gpu_video_decoder_host.cc
+++ b/chrome/renderer/gpu_video_decoder_host.cc
@@ -26,6 +26,8 @@ GpuVideoDecoderHost::GpuVideoDecoderHost(MessageRouter* router,
memset(&config_, 0, sizeof(config_));
}
+GpuVideoDecoderHost::~GpuVideoDecoderHost() {}
+
void GpuVideoDecoderHost::OnChannelError() {
ipc_sender_ = NULL;
}
diff --git a/chrome/renderer/gpu_video_decoder_host.h b/chrome/renderer/gpu_video_decoder_host.h
index baf0ffe..c32a9f0 100644
--- a/chrome/renderer/gpu_video_decoder_host.h
+++ b/chrome/renderer/gpu_video_decoder_host.h
@@ -45,7 +45,7 @@ class GpuVideoDecoderHost : public media::VideoDecodeEngine,
IPC::Message::Sender* ipc_sender,
int context_route_id,
int32 decoder_host_id);
- virtual ~GpuVideoDecoderHost() {}
+ virtual ~GpuVideoDecoderHost();
// IPC::Channel::Listener.
virtual void OnChannelConnected(int32 peer_pid) {}
diff --git a/chrome/renderer/paint_aggregator.cc b/chrome/renderer/paint_aggregator.cc
index 943e012..991053f 100644
--- a/chrome/renderer/paint_aggregator.cc
+++ b/chrome/renderer/paint_aggregator.cc
@@ -34,6 +34,10 @@ static const float kMaxRedundantPaintToScrollArea = 0.8f;
// a paint rect can be significant.
static const size_t kMaxPaintRects = 5;
+PaintAggregator::PendingUpdate::PendingUpdate() {}
+
+PaintAggregator::PendingUpdate::~PendingUpdate() {}
+
gfx::Rect PaintAggregator::PendingUpdate::GetScrollDamage() const {
// Should only be scrolling in one direction at a time.
DCHECK(!(scroll_delta.x() && scroll_delta.y()));
diff --git a/chrome/renderer/paint_aggregator.h b/chrome/renderer/paint_aggregator.h
index 6efac35..119e0b5 100644
--- a/chrome/renderer/paint_aggregator.h
+++ b/chrome/renderer/paint_aggregator.h
@@ -8,6 +8,7 @@
#include <vector>
+#include "base/basictypes.h"
#include "gfx/rect.h"
// This class is responsible for aggregating multiple invalidation and scroll
@@ -22,9 +23,8 @@ class PaintAggregator {
// |scroll_delta| can only specify scrolling in one direction (i.e., the x
// and y members cannot both be non-zero).
struct PendingUpdate {
- gfx::Point scroll_delta;
- gfx::Rect scroll_rect;
- std::vector<gfx::Rect> paint_rects;
+ PendingUpdate();
+ ~PendingUpdate();
// Returns the rect damaged by scrolling within |scroll_rect| by
// |scroll_delta|. This rect must be repainted.
@@ -32,6 +32,10 @@ class PaintAggregator {
// Returns the smallest rect containing all paint rects.
gfx::Rect GetPaintBounds() const;
+
+ gfx::Point scroll_delta;
+ gfx::Rect scroll_rect;
+ std::vector<gfx::Rect> paint_rects;
};
// There is a PendingUpdate if InvalidateRect or ScrollRect were called and
diff --git a/chrome/renderer/pepper_devices.cc b/chrome/renderer/pepper_devices.cc
index 07da49d..57189d4 100644
--- a/chrome/renderer/pepper_devices.cc
+++ b/chrome/renderer/pepper_devices.cc
@@ -20,11 +20,30 @@ const uint32 kBytesPerPixel = 4; // Only 8888 RGBA for now.
int Graphics2DDeviceContext::next_buffer_id_ = 0;
+struct Graphics2DDeviceContext::FlushCallbackData {
+ FlushCallbackData(NPDeviceFlushContextCallbackPtr f,
+ NPP n,
+ NPDeviceContext2D* c,
+ NPUserData* u)
+ : function(f),
+ npp(n),
+ context(c),
+ user_data(u) {
+ }
+
+ NPDeviceFlushContextCallbackPtr function;
+ NPP npp;
+ NPDeviceContext2D* context;
+ NPUserData* user_data;
+};
+
Graphics2DDeviceContext::Graphics2DDeviceContext(
WebPluginDelegatePepper* plugin_delegate)
: plugin_delegate_(plugin_delegate) {
}
+Graphics2DDeviceContext::~Graphics2DDeviceContext() {}
+
NPError Graphics2DDeviceContext::Initialize(
gfx::Rect window_rect, const NPDeviceContext2DConfig* config,
NPDeviceContext2D* context) {
@@ -153,6 +172,12 @@ void Graphics2DDeviceContext::RenderViewFlushedPaint() {
painted_flush_callbacks_.clear();
}
+AudioDeviceContext::AudioDeviceContext()
+ : context_(NULL),
+ stream_id_(0),
+ shared_memory_size_(0) {
+}
+
AudioDeviceContext::~AudioDeviceContext() {
if (stream_id_) {
OnDestroy();
diff --git a/chrome/renderer/pepper_devices.h b/chrome/renderer/pepper_devices.h
index 2a72f4e..912657a 100644
--- a/chrome/renderer/pepper_devices.h
+++ b/chrome/renderer/pepper_devices.h
@@ -27,6 +27,7 @@ class SkBitmap;
class Graphics2DDeviceContext {
public:
explicit Graphics2DDeviceContext(WebPluginDelegatePepper* plugin_delegate);
+ ~Graphics2DDeviceContext();
NPError Initialize(gfx::Rect window_rect,
const NPDeviceContext2DConfig* config,
@@ -45,22 +46,7 @@ class Graphics2DDeviceContext {
skia::PlatformCanvas* canvas() { return canvas_.get(); }
private:
- struct FlushCallbackData {
- FlushCallbackData(NPDeviceFlushContextCallbackPtr f,
- NPP n,
- NPDeviceContext2D* c,
- NPUserData* u)
- : function(f),
- npp(n),
- context(c),
- user_data(u) {
- }
-
- NPDeviceFlushContextCallbackPtr function;
- NPP npp;
- NPDeviceContext2D* context;
- NPUserData* user_data;
- };
+ struct FlushCallbackData;
typedef std::vector<FlushCallbackData> FlushCallbackVector;
WebPluginDelegatePepper* plugin_delegate_;
@@ -97,11 +83,7 @@ class Graphics2DDeviceContext {
class AudioDeviceContext : public AudioMessageFilter::Delegate,
public base::DelegateSimpleThread::Delegate {
public:
- explicit AudioDeviceContext()
- : context_(NULL),
- stream_id_(0),
- shared_memory_size_(0) {
- }
+ explicit AudioDeviceContext();
virtual ~AudioDeviceContext();
NPError Initialize(AudioMessageFilter* filter,
diff --git a/chrome/renderer/pepper_plugin_delegate_impl.cc b/chrome/renderer/pepper_plugin_delegate_impl.cc
index cb37c0b..ecaf0e4 100644
--- a/chrome/renderer/pepper_plugin_delegate_impl.cc
+++ b/chrome/renderer/pepper_plugin_delegate_impl.cc
@@ -495,6 +495,8 @@ PepperPluginDelegateImpl::PepperPluginDelegateImpl(RenderView* render_view)
id_generator_(0) {
}
+PepperPluginDelegateImpl::~PepperPluginDelegateImpl() {}
+
void PepperPluginDelegateImpl::ViewInitiatedPaint() {
// Notify all of our instances that we started painting. This is used for
// internal bookkeeping only, so we know that the set can not change under
diff --git a/chrome/renderer/pepper_plugin_delegate_impl.h b/chrome/renderer/pepper_plugin_delegate_impl.h
index fc1c5b8..a1fb6a0 100644
--- a/chrome/renderer/pepper_plugin_delegate_impl.h
+++ b/chrome/renderer/pepper_plugin_delegate_impl.h
@@ -40,7 +40,7 @@ class PepperPluginDelegateImpl
public base::SupportsWeakPtr<PepperPluginDelegateImpl> {
public:
explicit PepperPluginDelegateImpl(RenderView* render_view);
- virtual ~PepperPluginDelegateImpl() {}
+ virtual ~PepperPluginDelegateImpl();
// Called by RenderView to tell us about painting events, these two functions
// just correspond to the DidInitiatePaint and DidFlushPaint in R.V..
diff --git a/chrome/renderer/user_script_slave.cc b/chrome/renderer/user_script_slave.cc
index 8639d43..dba1dcf 100644
--- a/chrome/renderer/user_script_slave.cc
+++ b/chrome/renderer/user_script_slave.cc
@@ -67,6 +67,8 @@ UserScriptSlave::UserScriptSlave()
IDR_GREASEMONKEY_API_JS);
}
+UserScriptSlave::~UserScriptSlave() {}
+
void UserScriptSlave::GetActiveExtensions(
std::set<std::string>* extension_ids) {
for (size_t i = 0; i < scripts_.size(); ++i) {
diff --git a/chrome/renderer/user_script_slave.h b/chrome/renderer/user_script_slave.h
index 7df6b17..23acb4c 100644
--- a/chrome/renderer/user_script_slave.h
+++ b/chrome/renderer/user_script_slave.h
@@ -27,6 +27,7 @@ using WebKit::WebScriptSource;
class UserScriptSlave {
public:
UserScriptSlave();
+ ~UserScriptSlave();
// Returns the unique set of extension IDs this UserScriptSlave knows about.
void GetActiveExtensions(std::set<std::string>* extension_ids);
diff --git a/chrome/renderer/websharedworkerrepository_impl.cc b/chrome/renderer/websharedworkerrepository_impl.cc
index 99f2a3b..29c9ed6 100644
--- a/chrome/renderer/websharedworkerrepository_impl.cc
+++ b/chrome/renderer/websharedworkerrepository_impl.cc
@@ -8,6 +8,10 @@
#include "chrome/renderer/render_thread.h"
#include "chrome/renderer/websharedworker_proxy.h"
+WebSharedWorkerRepositoryImpl::WebSharedWorkerRepositoryImpl() {}
+
+WebSharedWorkerRepositoryImpl::~WebSharedWorkerRepositoryImpl() {}
+
void WebSharedWorkerRepositoryImpl::addSharedWorker(
WebKit::WebSharedWorker* worker, DocumentID document) {
shared_worker_parents_.insert(document);
diff --git a/chrome/renderer/websharedworkerrepository_impl.h b/chrome/renderer/websharedworkerrepository_impl.h
index b11e4a7..1bcbfa9 100644
--- a/chrome/renderer/websharedworkerrepository_impl.h
+++ b/chrome/renderer/websharedworkerrepository_impl.h
@@ -16,7 +16,8 @@ class WebSharedWorker;
class WebSharedWorkerRepositoryImpl : public WebKit::WebSharedWorkerRepository {
public:
- virtual ~WebSharedWorkerRepositoryImpl() {}
+ WebSharedWorkerRepositoryImpl();
+ virtual ~WebSharedWorkerRepositoryImpl();
virtual void addSharedWorker(WebKit::WebSharedWorker*, DocumentID document);
virtual void documentDetached(DocumentID document);
diff --git a/chrome/service/cloud_print/print_system.cc b/chrome/service/cloud_print/print_system.cc
new file mode 100644
index 0000000..57c1342
--- /dev/null
+++ b/chrome/service/cloud_print/print_system.cc
@@ -0,0 +1,36 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/service/cloud_print/print_system.h"
+
+namespace cloud_print {
+
+PrinterBasicInfo::PrinterBasicInfo() : printer_status(0) {}
+
+PrinterBasicInfo::~PrinterBasicInfo() {}
+
+PrintJobDetails::PrintJobDetails()
+ : status(PRINT_JOB_STATUS_INVALID),
+ platform_status_flags(0),
+ total_pages(0),
+ pages_printed(0) {
+}
+
+void PrintJobDetails::Clear() {
+ status = PRINT_JOB_STATUS_INVALID;
+ platform_status_flags = 0;
+ status_message.clear();
+ total_pages = 0;
+ pages_printed = 0;
+}
+
+PrintSystem::PrintServerWatcher::~PrintServerWatcher() {}
+
+PrintSystem::PrinterWatcher::~PrinterWatcher() {}
+
+PrintSystem::JobSpooler::~JobSpooler() {}
+
+PrintSystem::~PrintSystem() {}
+
+} // namespace cloud_print
diff --git a/chrome/service/cloud_print/print_system.h b/chrome/service/cloud_print/print_system.h
index b0e287d..2abdcc3 100644
--- a/chrome/service/cloud_print/print_system.h
+++ b/chrome/service/cloud_print/print_system.h
@@ -21,12 +21,13 @@ namespace cloud_print {
typedef int PlatformJobId;
struct PrinterBasicInfo {
+ PrinterBasicInfo();
+ ~PrinterBasicInfo();
+
std::string printer_name;
std::string printer_description;
int printer_status;
std::map<std::string, std::string> options;
- PrinterBasicInfo() : printer_status(0) {
- }
};
typedef std::vector<PrinterBasicInfo> PrinterList;
@@ -46,22 +47,10 @@ enum PrintJobStatus {
};
struct PrintJobDetails {
- PrintJobStatus status;
- int platform_status_flags;
- std::string status_message;
- int total_pages;
- int pages_printed;
- PrintJobDetails() : status(PRINT_JOB_STATUS_INVALID),
- platform_status_flags(0), total_pages(0),
- pages_printed(0) {
- }
- void Clear() {
- status = PRINT_JOB_STATUS_INVALID;
- platform_status_flags = 0;
- status_message.clear();
- total_pages = 0;
- pages_printed = 0;
- }
+ PrintJobDetails();
+
+ void Clear();
+
bool operator ==(const PrintJobDetails& other) const {
return (status == other.status) &&
(platform_status_flags == other.platform_status_flags) &&
@@ -69,9 +58,16 @@ struct PrintJobDetails {
(total_pages == other.total_pages) &&
(pages_printed == other.pages_printed);
}
+
bool operator !=(const PrintJobDetails& other) const {
return !(*this == other);
}
+
+ PrintJobStatus status;
+ int platform_status_flags;
+ std::string status_message;
+ int total_pages;
+ int pages_printed;
};
// PrintSystem class will provide interface for different printing systems
@@ -96,7 +92,7 @@ class PrintSystem : public base::RefCountedThreadSafe<PrintSystem> {
virtual ~Delegate() {}
};
- virtual ~PrintServerWatcher() {}
+ virtual ~PrintServerWatcher();
virtual bool StartWatching(PrintServerWatcher::Delegate* delegate) = 0;
virtual bool StopWatching() = 0;
};
@@ -114,7 +110,7 @@ class PrintSystem : public base::RefCountedThreadSafe<PrintSystem> {
virtual ~Delegate() {}
};
- virtual ~PrinterWatcher() {}
+ virtual ~PrinterWatcher();
virtual bool StartWatching(PrinterWatcher::Delegate* delegate) = 0;
virtual bool StopWatching() = 0;
virtual bool GetCurrentPrinterInfo(PrinterBasicInfo* printer_info) = 0;
@@ -130,7 +126,7 @@ class PrintSystem : public base::RefCountedThreadSafe<PrintSystem> {
virtual void OnJobSpoolFailed() = 0;
};
- virtual ~JobSpooler() {}
+ virtual ~JobSpooler();
// Spool job to the printer asynchronously. Caller will be notified via
// |delegate|. Note that only one print job can be in progress at any given
// time. Subsequent calls to Spool (before the Delegate::OnJobSpoolSucceeded
@@ -143,7 +139,7 @@ class PrintSystem : public base::RefCountedThreadSafe<PrintSystem> {
JobSpooler::Delegate* delegate) = 0;
};
- virtual ~PrintSystem() {}
+ virtual ~PrintSystem();
// Enumerates the list of installed local and network printers.
virtual void EnumeratePrinters(PrinterList* printer_list) = 0;