OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/predictors/predictor_database.h" | 5 #include "chrome/browser/predictors/predictor_database.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/files/file_path.h" | 8 #include "base/files/file_path.h" |
9 #include "base/files/file_util.h" | 9 #include "base/files/file_util.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/metrics/histogram.h" | 11 #include "base/metrics/histogram.h" |
12 #include "base/strings/stringprintf.h" | 12 #include "base/strings/stringprintf.h" |
13 #include "chrome/browser/predictors/autocomplete_action_predictor_table.h" | 13 #include "chrome/browser/predictors/autocomplete_action_predictor_table.h" |
14 #include "chrome/browser/predictors/logged_in_predictor_table.h" | 14 #include "chrome/browser/predictors/logged_in_predictor_table.h" |
| 15 #include "chrome/browser/predictors/resource_prefetch_predictor.h" |
| 16 #include "chrome/browser/predictors/resource_prefetch_predictor_tables.h" |
15 #include "chrome/browser/prerender/prerender_field_trial.h" | 17 #include "chrome/browser/prerender/prerender_field_trial.h" |
16 #include "chrome/browser/profiles/profile.h" | 18 #include "chrome/browser/profiles/profile.h" |
17 #include "content/public/browser/browser_thread.h" | 19 #include "content/public/browser/browser_thread.h" |
18 #include "sql/connection.h" | 20 #include "sql/connection.h" |
19 #include "sql/statement.h" | 21 #include "sql/statement.h" |
20 | 22 |
21 using content::BrowserThread; | 23 using content::BrowserThread; |
22 | 24 |
23 namespace { | 25 namespace { |
24 | 26 |
(...skipping 18 matching lines...) Expand all Loading... |
43 | 45 |
44 // Opens the database file from the profile path. Separated from the | 46 // Opens the database file from the profile path. Separated from the |
45 // constructor to ease construction/destruction of this object on one thread | 47 // constructor to ease construction/destruction of this object on one thread |
46 // but database access on the DB thread. | 48 // but database access on the DB thread. |
47 void Initialize(); | 49 void Initialize(); |
48 void LogDatabaseStats(); // DB Thread. | 50 void LogDatabaseStats(); // DB Thread. |
49 | 51 |
50 // Cancels pending DB transactions. Should only be called on the UI thread. | 52 // Cancels pending DB transactions. Should only be called on the UI thread. |
51 void SetCancelled(); | 53 void SetCancelled(); |
52 | 54 |
| 55 bool is_resource_prefetch_predictor_enabled_; |
53 base::FilePath db_path_; | 56 base::FilePath db_path_; |
54 scoped_ptr<sql::Connection> db_; | 57 scoped_ptr<sql::Connection> db_; |
55 | 58 |
56 // TODO(shishir): These tables may not need to be refcounted. Maybe move them | 59 // TODO(shishir): These tables may not need to be refcounted. Maybe move them |
57 // to using a WeakPtr instead. | 60 // to using a WeakPtr instead. |
58 scoped_refptr<AutocompleteActionPredictorTable> autocomplete_table_; | 61 scoped_refptr<AutocompleteActionPredictorTable> autocomplete_table_; |
59 scoped_refptr<LoggedInPredictorTable> logged_in_table_; | 62 scoped_refptr<LoggedInPredictorTable> logged_in_table_; |
| 63 scoped_refptr<ResourcePrefetchPredictorTables> resource_prefetch_tables_; |
60 | 64 |
61 DISALLOW_COPY_AND_ASSIGN(PredictorDatabaseInternal); | 65 DISALLOW_COPY_AND_ASSIGN(PredictorDatabaseInternal); |
62 }; | 66 }; |
63 | 67 |
64 | 68 |
65 PredictorDatabaseInternal::PredictorDatabaseInternal(Profile* profile) | 69 PredictorDatabaseInternal::PredictorDatabaseInternal(Profile* profile) |
66 : db_path_(profile->GetPath().Append(kPredictorDatabaseName)), | 70 : db_path_(profile->GetPath().Append(kPredictorDatabaseName)), |
67 db_(new sql::Connection()), | 71 db_(new sql::Connection()), |
68 autocomplete_table_(new AutocompleteActionPredictorTable()), | 72 autocomplete_table_(new AutocompleteActionPredictorTable()), |
69 logged_in_table_(new LoggedInPredictorTable()) { | 73 logged_in_table_(new LoggedInPredictorTable()), |
| 74 resource_prefetch_tables_(new ResourcePrefetchPredictorTables()) { |
70 db_->set_histogram_tag("Predictor"); | 75 db_->set_histogram_tag("Predictor"); |
| 76 ResourcePrefetchPredictorConfig config; |
| 77 is_resource_prefetch_predictor_enabled_ = |
| 78 IsSpeculativeResourcePrefetchingEnabled(profile, &config); |
71 } | 79 } |
72 | 80 |
73 PredictorDatabaseInternal::~PredictorDatabaseInternal() { | 81 PredictorDatabaseInternal::~PredictorDatabaseInternal() { |
74 // The connection pointer needs to be deleted on the DB thread since there | 82 // The connection pointer needs to be deleted on the DB thread since there |
75 // might be a task in progress on the DB thread which uses this connection. | 83 // might be a task in progress on the DB thread which uses this connection. |
76 if (BrowserThread::IsMessageLoopValid(BrowserThread::DB)) | 84 if (BrowserThread::IsMessageLoopValid(BrowserThread::DB)) |
77 BrowserThread::DeleteSoon(BrowserThread::DB, FROM_HERE, db_.release()); | 85 BrowserThread::DeleteSoon(BrowserThread::DB, FROM_HERE, db_.release()); |
78 } | 86 } |
79 | 87 |
80 void PredictorDatabaseInternal::Initialize() { | 88 void PredictorDatabaseInternal::Initialize() { |
81 CHECK(BrowserThread::CurrentlyOn(BrowserThread::DB) || | 89 CHECK(BrowserThread::CurrentlyOn(BrowserThread::DB) || |
82 !BrowserThread::IsMessageLoopValid(BrowserThread::DB)); | 90 !BrowserThread::IsMessageLoopValid(BrowserThread::DB)); |
83 // TODO(tburkard): figure out if we need this. | 91 // TODO(tburkard): figure out if we need this. |
84 // db_->set_exclusive_locking(); | 92 // db_->set_exclusive_locking(); |
85 bool success = db_->Open(db_path_); | 93 bool success = db_->Open(db_path_); |
86 | 94 |
87 if (!success) | 95 if (!success) |
88 return; | 96 return; |
89 | 97 |
90 autocomplete_table_->Initialize(db_.get()); | 98 autocomplete_table_->Initialize(db_.get()); |
91 logged_in_table_->Initialize(db_.get()); | 99 logged_in_table_->Initialize(db_.get()); |
| 100 resource_prefetch_tables_->Initialize(db_.get()); |
92 | 101 |
93 LogDatabaseStats(); | 102 LogDatabaseStats(); |
94 } | 103 } |
95 | 104 |
96 void PredictorDatabaseInternal::SetCancelled() { | 105 void PredictorDatabaseInternal::SetCancelled() { |
97 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI) || | 106 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI) || |
98 !BrowserThread::IsMessageLoopValid(BrowserThread::UI)); | 107 !BrowserThread::IsMessageLoopValid(BrowserThread::UI)); |
99 | 108 |
100 autocomplete_table_->SetCancelled(); | 109 autocomplete_table_->SetCancelled(); |
101 logged_in_table_->SetCancelled(); | 110 logged_in_table_->SetCancelled(); |
| 111 resource_prefetch_tables_->SetCancelled(); |
102 } | 112 } |
103 | 113 |
104 void PredictorDatabaseInternal::LogDatabaseStats() { | 114 void PredictorDatabaseInternal::LogDatabaseStats() { |
105 CHECK(BrowserThread::CurrentlyOn(BrowserThread::DB) || | 115 CHECK(BrowserThread::CurrentlyOn(BrowserThread::DB) || |
106 !BrowserThread::IsMessageLoopValid(BrowserThread::DB)); | 116 !BrowserThread::IsMessageLoopValid(BrowserThread::DB)); |
107 | 117 |
108 int64 db_size; | 118 int64 db_size; |
109 bool success = base::GetFileSize(db_path_, &db_size); | 119 bool success = base::GetFileSize(db_path_, &db_size); |
110 DCHECK(success) << "Failed to get file size for " << db_path_.value(); | 120 DCHECK(success) << "Failed to get file size for " << db_path_.value(); |
111 UMA_HISTOGRAM_MEMORY_KB("PredictorDatabase.DatabaseSizeKB", | 121 UMA_HISTOGRAM_MEMORY_KB("PredictorDatabase.DatabaseSizeKB", |
112 static_cast<int>(db_size / 1024)); | 122 static_cast<int>(db_size / 1024)); |
113 | 123 |
114 autocomplete_table_->LogDatabaseStats(); | 124 autocomplete_table_->LogDatabaseStats(); |
115 logged_in_table_->LogDatabaseStats(); | 125 logged_in_table_->LogDatabaseStats(); |
| 126 if (is_resource_prefetch_predictor_enabled_) |
| 127 resource_prefetch_tables_->LogDatabaseStats(); |
116 } | 128 } |
117 | 129 |
118 PredictorDatabase::PredictorDatabase(Profile* profile) | 130 PredictorDatabase::PredictorDatabase(Profile* profile) |
119 : db_(new PredictorDatabaseInternal(profile)) { | 131 : db_(new PredictorDatabaseInternal(profile)) { |
120 BrowserThread::PostTask(BrowserThread::DB, FROM_HERE, | 132 BrowserThread::PostTask(BrowserThread::DB, FROM_HERE, |
121 base::Bind(&PredictorDatabaseInternal::Initialize, db_)); | 133 base::Bind(&PredictorDatabaseInternal::Initialize, db_)); |
122 } | 134 } |
123 | 135 |
124 PredictorDatabase::~PredictorDatabase() { | 136 PredictorDatabase::~PredictorDatabase() { |
125 } | 137 } |
126 | 138 |
127 void PredictorDatabase::Shutdown() { | 139 void PredictorDatabase::Shutdown() { |
128 db_->SetCancelled(); | 140 db_->SetCancelled(); |
129 } | 141 } |
130 | 142 |
131 scoped_refptr<AutocompleteActionPredictorTable> | 143 scoped_refptr<AutocompleteActionPredictorTable> |
132 PredictorDatabase::autocomplete_table() { | 144 PredictorDatabase::autocomplete_table() { |
133 return db_->autocomplete_table_; | 145 return db_->autocomplete_table_; |
134 } | 146 } |
135 | 147 |
136 scoped_refptr<LoggedInPredictorTable> | 148 scoped_refptr<LoggedInPredictorTable> |
137 PredictorDatabase::logged_in_table() { | 149 PredictorDatabase::logged_in_table() { |
138 return db_->logged_in_table_; | 150 return db_->logged_in_table_; |
139 } | 151 } |
140 | 152 |
| 153 scoped_refptr<ResourcePrefetchPredictorTables> |
| 154 PredictorDatabase::resource_prefetch_tables() { |
| 155 return db_->resource_prefetch_tables_; |
| 156 } |
| 157 |
141 sql::Connection* PredictorDatabase::GetDatabase() { | 158 sql::Connection* PredictorDatabase::GetDatabase() { |
142 return db_->db_.get(); | 159 return db_->db_.get(); |
143 } | 160 } |
144 | 161 |
145 } // namespace predictors | 162 } // namespace predictors |
OLD | NEW |