| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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 "app/sql/transaction.h" | 5 #include "app/sql/transaction.h" |
| 6 #include "base/string_util.h" | 6 #include "base/string_util.h" |
| 7 #include "chrome/browser/diagnostics/sqlite_diagnostics.h" | 7 #include "chrome/browser/diagnostics/sqlite_diagnostics.h" |
| 8 #include "chrome/browser/history/top_sites.h" | 8 #include "chrome/browser/history/top_sites.h" |
| 9 #include "chrome/browser/history/top_sites_database.h" | 9 #include "chrome/browser/history/top_sites_database.h" |
| 10 | 10 |
| (...skipping 16 matching lines...) Expand all Loading... |
| 27 return InitThumbnailTable(); | 27 return InitThumbnailTable(); |
| 28 } | 28 } |
| 29 | 29 |
| 30 bool TopSitesDatabaseImpl::InitThumbnailTable() { | 30 bool TopSitesDatabaseImpl::InitThumbnailTable() { |
| 31 if (!db_.DoesTableExist("thumbnails")) { | 31 if (!db_.DoesTableExist("thumbnails")) { |
| 32 if (!db_.Execute("CREATE TABLE thumbnails (" | 32 if (!db_.Execute("CREATE TABLE thumbnails (" |
| 33 "url LONGVARCHAR PRIMARY KEY," | 33 "url LONGVARCHAR PRIMARY KEY," |
| 34 "url_rank INTEGER ," | 34 "url_rank INTEGER ," |
| 35 "title LONGVARCHAR," | 35 "title LONGVARCHAR," |
| 36 "thumbnail BLOB," | 36 "thumbnail BLOB," |
| 37 "redirects LONGVARCHAR)")) { | 37 "redirects LONGVARCHAR," |
| 38 "boring_score DOUBLE DEFAULT 1.0, " |
| 39 "good_clipping INTEGER DEFAULT 0, " |
| 40 "at_top INTEGER DEFAULT 0, " |
| 41 "last_updated INTEGER DEFAULT 0) ")) { |
| 38 LOG(WARNING) << db_.GetErrorMessage(); | 42 LOG(WARNING) << db_.GetErrorMessage(); |
| 39 return false; | 43 return false; |
| 40 } | 44 } |
| 41 } | 45 } |
| 42 return true; | 46 return true; |
| 43 } | 47 } |
| 44 | 48 |
| 45 MostVisitedURLList TopSitesDatabaseImpl::GetTopURLs() { | 49 MostVisitedURLList TopSitesDatabaseImpl::GetTopURLs() { |
| 46 MostVisitedURLList result; | 50 MostVisitedURLList result; |
| 47 sql::Statement select_statement(db_.GetCachedStatement( | 51 sql::Statement select_statement(db_.GetCachedStatement( |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 94 int new_rank, | 98 int new_rank, |
| 95 const TopSites::Images& thumbnail) { | 99 const TopSites::Images& thumbnail) { |
| 96 sql::Transaction transaction(&db_); | 100 sql::Transaction transaction(&db_); |
| 97 transaction.Begin(); | 101 transaction.Begin(); |
| 98 | 102 |
| 99 int prev_rank = GetURLRank(url); | 103 int prev_rank = GetURLRank(url); |
| 100 | 104 |
| 101 sql::Statement statement(db_.GetCachedStatement( | 105 sql::Statement statement(db_.GetCachedStatement( |
| 102 SQL_FROM_HERE, | 106 SQL_FROM_HERE, |
| 103 "INSERT OR REPLACE INTO thumbnails " | 107 "INSERT OR REPLACE INTO thumbnails " |
| 104 "(url, url_rank, title, thumbnail, redirects) " | 108 "(url, url_rank, title, thumbnail, redirects, " |
| 105 "VALUES (?, ?, ?, ?, ?)")); // TODO(Nik): add the rest of the schema. | 109 "boring_score, good_clipping, at_top, last_updated) " |
| 110 "VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)")); |
| 106 if (!statement) | 111 if (!statement) |
| 107 return; | 112 return; |
| 108 | 113 |
| 109 statement.BindString(0, url.url.spec()); | 114 statement.BindString(0, url.url.spec()); |
| 110 statement.BindInt(1, -1); // Temporary value | 115 statement.BindInt(1, -1); // Temporary value |
| 111 statement.BindString16(2, url.title); | 116 statement.BindString16(2, url.title); |
| 112 if (thumbnail.thumbnail.get()) { | 117 if (thumbnail.thumbnail.get()) { |
| 113 statement.BindBlob(3, &thumbnail.thumbnail->data.front(), | 118 statement.BindBlob(3, &thumbnail.thumbnail->data.front(), |
| 114 static_cast<int>(thumbnail.thumbnail->data.size())); | 119 static_cast<int>(thumbnail.thumbnail->data.size())); |
| 115 } | 120 } |
| 116 statement.BindString(4, GetRedirects(url)); | 121 statement.BindString(4, GetRedirects(url)); |
| 122 const ThumbnailScore& score = thumbnail.thumbnail_score; |
| 123 statement.BindDouble(5, score.boring_score); |
| 124 statement.BindBool(6, score.good_clipping); |
| 125 statement.BindBool(7, score.at_top); |
| 126 statement.BindInt64(8, score.time_at_snapshot.ToInternalValue()); |
| 117 | 127 |
| 118 if (!statement.Run()) | 128 if (!statement.Run()) |
| 119 NOTREACHED() << db_.GetErrorMessage(); | 129 NOTREACHED() << db_.GetErrorMessage(); |
| 120 | 130 |
| 121 // Shift the ranks. | 131 // Shift the ranks. |
| 122 if (prev_rank == -1) { | 132 if (prev_rank == -1) { |
| 123 // Shift up | 133 // Shift up |
| 124 sql::Statement shift_statement(db_.GetCachedStatement( | 134 sql::Statement shift_statement(db_.GetCachedStatement( |
| 125 SQL_FROM_HERE, | 135 SQL_FROM_HERE, |
| 126 "UPDATE thumbnails " | 136 "UPDATE thumbnails " |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 159 "SET url_rank = ? " | 169 "SET url_rank = ? " |
| 160 "WHERE url_rank == -1")); | 170 "WHERE url_rank == -1")); |
| 161 set_statement.BindInt(0, new_rank); | 171 set_statement.BindInt(0, new_rank); |
| 162 if (set_statement) | 172 if (set_statement) |
| 163 set_statement.Run(); | 173 set_statement.Run(); |
| 164 transaction.Commit(); | 174 transaction.Commit(); |
| 165 } | 175 } |
| 166 | 176 |
| 167 bool TopSitesDatabaseImpl::GetPageThumbnail(const MostVisitedURL& url, | 177 bool TopSitesDatabaseImpl::GetPageThumbnail(const MostVisitedURL& url, |
| 168 TopSites::Images* thumbnail) { | 178 TopSites::Images* thumbnail) { |
| 169 sql::Statement select_statement(db_.GetCachedStatement( | 179 sql::Statement statement(db_.GetCachedStatement( |
| 170 SQL_FROM_HERE, | 180 SQL_FROM_HERE, |
| 171 "SELECT thumbnail " | 181 "SELECT thumbnail, boring_score, good_clipping, at_top, last_updated " |
| 172 "FROM thumbnails WHERE url=?")); | 182 "FROM thumbnails WHERE url=?")); |
| 173 | 183 |
| 174 if (!select_statement) { | 184 if (!statement) { |
| 175 LOG(WARNING) << db_.GetErrorMessage(); | 185 LOG(WARNING) << db_.GetErrorMessage(); |
| 176 return false; | 186 return false; |
| 177 } | 187 } |
| 178 | 188 |
| 179 select_statement.BindString(0, url.url.spec()); | 189 statement.BindString(0, url.url.spec()); |
| 180 if (!select_statement.Step()) | 190 if (!statement.Step()) |
| 181 return false; | 191 return false; |
| 182 | 192 |
| 183 std::vector<unsigned char> data; | 193 std::vector<unsigned char> data; |
| 184 select_statement.ColumnBlobAsVector(0, &data); | 194 statement.ColumnBlobAsVector(0, &data); |
| 185 thumbnail->thumbnail = RefCountedBytes::TakeVector(&data); | 195 thumbnail->thumbnail = RefCountedBytes::TakeVector(&data); |
| 196 thumbnail->thumbnail_score.boring_score = statement.ColumnDouble(1); |
| 197 thumbnail->thumbnail_score.good_clipping = statement.ColumnBool(2); |
| 198 thumbnail->thumbnail_score.at_top = statement.ColumnBool(3); |
| 199 thumbnail->thumbnail_score.time_at_snapshot = |
| 200 base::Time::FromInternalValue(statement.ColumnInt64(4)); |
| 186 return true; | 201 return true; |
| 187 } | 202 } |
| 188 | 203 |
| 189 int TopSitesDatabaseImpl::GetURLRank(const MostVisitedURL& url) { | 204 int TopSitesDatabaseImpl::GetURLRank(const MostVisitedURL& url) { |
| 190 int result = -1; | 205 int result = -1; |
| 191 sql::Statement select_statement(db_.GetCachedStatement( | 206 sql::Statement select_statement(db_.GetCachedStatement( |
| 192 SQL_FROM_HERE, | 207 SQL_FROM_HERE, |
| 193 "SELECT url_rank " | 208 "SELECT url_rank " |
| 194 "FROM thumbnails WHERE url=?")); | 209 "FROM thumbnails WHERE url=?")); |
| 195 if (!select_statement) { | 210 if (!select_statement) { |
| (...skipping 29 matching lines...) Expand all Loading... |
| 225 "DELETE FROM thumbnails WHERE url = ?")); | 240 "DELETE FROM thumbnails WHERE url = ?")); |
| 226 if (!delete_statement) | 241 if (!delete_statement) |
| 227 return false; | 242 return false; |
| 228 delete_statement.BindString(0, url.url.spec()); | 243 delete_statement.BindString(0, url.url.spec()); |
| 229 delete_statement.Run(); | 244 delete_statement.Run(); |
| 230 | 245 |
| 231 return transaction.Commit(); | 246 return transaction.Commit(); |
| 232 } | 247 } |
| 233 | 248 |
| 234 } // namespace history | 249 } // namespace history |
| 235 | |
| OLD | NEW |