Index: chrome/browser/predictors/autocomplete_action_predictor.cc |
diff --git a/chrome/browser/autocomplete/network_action_predictor.cc b/chrome/browser/predictors/autocomplete_action_predictor.cc |
similarity index 81% |
rename from chrome/browser/autocomplete/network_action_predictor.cc |
rename to chrome/browser/predictors/autocomplete_action_predictor.cc |
index 310200e906c537bdde98dbba818c35818225df10..6c2d77ad03cb0574a156b78177e9a9895d582c4d 100644 |
--- a/chrome/browser/autocomplete/network_action_predictor.cc |
+++ b/chrome/browser/predictors/autocomplete_action_predictor.cc |
@@ -2,7 +2,7 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "chrome/browser/autocomplete/network_action_predictor.h" |
+#include "chrome/browser/predictors/autocomplete_action_predictor.h" |
#include <math.h> |
@@ -16,10 +16,10 @@ |
#include "base/utf_string_conversions.h" |
#include "chrome/browser/autocomplete/autocomplete.h" |
#include "chrome/browser/autocomplete/autocomplete_match.h" |
-#include "chrome/browser/autocomplete/network_action_predictor_database.h" |
#include "chrome/browser/history/history.h" |
#include "chrome/browser/history/history_notifications.h" |
#include "chrome/browser/history/in_memory_database.h" |
+#include "chrome/browser/predictors/autocomplete_action_predictor_database.h" |
#include "chrome/browser/prerender/prerender_field_trial.h" |
#include "chrome/browser/prerender/prerender_manager.h" |
#include "chrome/browser/prerender/prerender_manager_factory.h" |
@@ -42,7 +42,7 @@ const size_t kMinimumUserTextLength = 1; |
const int kMinimumNumberOfHits = 3; |
COMPILE_ASSERT(arraysize(kConfidenceCutoff) == |
- NetworkActionPredictor::LAST_PREDICT_ACTION, |
+ AutocompleteActionPredictor::LAST_PREDICT_ACTION, |
ConfidenceCutoff_count_mismatch); |
enum DatabaseAction { |
@@ -70,16 +70,16 @@ bool IsAutocompleteMatchSearchType(const AutocompleteMatch& match) { |
} |
-const int NetworkActionPredictor::kMaximumDaysToKeepEntry = 14; |
+const int AutocompleteActionPredictor::kMaximumDaysToKeepEntry = 14; |
-double NetworkActionPredictor::hit_weight_ = 1.0; |
+double AutocompleteActionPredictor::hit_weight_ = 1.0; |
-NetworkActionPredictor::NetworkActionPredictor(Profile* profile) |
+AutocompleteActionPredictor::AutocompleteActionPredictor(Profile* profile) |
: profile_(profile), |
- db_(new NetworkActionPredictorDatabase(profile)), |
+ db_(new AutocompleteActionPredictorDatabase(profile)), |
initialized_(false) { |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::Initialize, db_)); |
+ base::Bind(&AutocompleteActionPredictorDatabase::Initialize, db_)); |
// Request the in-memory database from the history to force it to load so it's |
// available as soon as possible. |
@@ -91,20 +91,20 @@ NetworkActionPredictor::NetworkActionPredictor(Profile* profile) |
// Create local caches using the database as loaded. We will garbage collect |
// rows from the caches and the database once the history service is |
// available. |
- std::vector<NetworkActionPredictorDatabase::Row>* rows = |
- new std::vector<NetworkActionPredictorDatabase::Row>(); |
+ std::vector<AutocompleteActionPredictorDatabase::Row>* rows = |
+ new std::vector<AutocompleteActionPredictorDatabase::Row>(); |
content::BrowserThread::PostTaskAndReply( |
content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::GetAllRows, db_, rows), |
- base::Bind(&NetworkActionPredictor::CreateCaches, AsWeakPtr(), |
+ base::Bind(&AutocompleteActionPredictorDatabase::GetAllRows, db_, rows), |
+ base::Bind(&AutocompleteActionPredictor::CreateCaches, AsWeakPtr(), |
base::Owned(rows))); |
} |
-NetworkActionPredictor::~NetworkActionPredictor() { |
+AutocompleteActionPredictor::~AutocompleteActionPredictor() { |
} |
-void NetworkActionPredictor::RegisterTransitionalMatches( |
+void AutocompleteActionPredictor::RegisterTransitionalMatches( |
const string16& user_text, |
const AutocompleteResult& result) { |
if (user_text.length() < kMinimumUserTextLength) |
@@ -132,14 +132,15 @@ void NetworkActionPredictor::RegisterTransitionalMatches( |
} |
} |
-void NetworkActionPredictor::ClearTransitionalMatches() { |
+void AutocompleteActionPredictor::ClearTransitionalMatches() { |
transitional_matches_.clear(); |
} |
// Given a match, return a recommended action. |
-NetworkActionPredictor::Action NetworkActionPredictor::RecommendAction( |
- const string16& user_text, |
- const AutocompleteMatch& match) const { |
+AutocompleteActionPredictor::Action |
+ AutocompleteActionPredictor::RecommendAction( |
+ const string16& user_text, |
+ const AutocompleteMatch& match) const { |
bool is_in_db = false; |
const double confidence = CalculateConfidence(user_text, match, &is_in_db); |
DCHECK(confidence >= 0.0 && confidence <= 1.0); |
@@ -181,15 +182,16 @@ NetworkActionPredictor::Action NetworkActionPredictor::RecommendAction( |
// Return true if the suggestion type warrants a TCP/IP preconnection. |
// i.e., it is now quite likely that the user will select the related domain. |
// static |
-bool NetworkActionPredictor::IsPreconnectable(const AutocompleteMatch& match) { |
+bool AutocompleteActionPredictor::IsPreconnectable( |
+ const AutocompleteMatch& match) { |
return IsAutocompleteMatchSearchType(match); |
} |
-void NetworkActionPredictor::Shutdown() { |
+void AutocompleteActionPredictor::Shutdown() { |
db_->OnPredictorDestroyed(); |
} |
-void NetworkActionPredictor::Observe( |
+void AutocompleteActionPredictor::Observe( |
int type, |
const content::NotificationSource& source, |
const content::NotificationDetails& details) { |
@@ -234,7 +236,8 @@ void NetworkActionPredictor::Observe( |
} |
} |
-void NetworkActionPredictor::OnOmniboxOpenedUrl(const AutocompleteLog& log) { |
+void AutocompleteActionPredictor::OnOmniboxOpenedUrl( |
+ const AutocompleteLog& log) { |
if (log.text.length() < kMinimumUserTextLength) |
return; |
@@ -275,7 +278,7 @@ void NetworkActionPredictor::OnOmniboxOpenedUrl(const AutocompleteLog& log) { |
const DBCacheKey key = { it->user_text, *url_it }; |
const bool is_hit = (*url_it == opened_url); |
- NetworkActionPredictorDatabase::Row row; |
+ AutocompleteActionPredictorDatabase::Row row; |
row.user_text = key.user_text; |
row.url = key.url; |
@@ -313,9 +316,9 @@ void NetworkActionPredictor::OnOmniboxOpenedUrl(const AutocompleteLog& log) { |
tracked_urls_.clear(); |
} |
-void NetworkActionPredictor::DeleteOldIdsFromCaches( |
+void AutocompleteActionPredictor::DeleteOldIdsFromCaches( |
history::URLDatabase* url_db, |
- std::vector<NetworkActionPredictorDatabase::Row::Id>* id_list) { |
+ std::vector<AutocompleteActionPredictorDatabase::Row::Id>* id_list) { |
CHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
DCHECK(url_db); |
DCHECK(id_list); |
@@ -337,15 +340,16 @@ void NetworkActionPredictor::DeleteOldIdsFromCaches( |
} |
} |
-void NetworkActionPredictor::DeleteOldEntries(history::URLDatabase* url_db) { |
+void AutocompleteActionPredictor::DeleteOldEntries( |
+ history::URLDatabase* url_db) { |
CHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
DCHECK(!initialized_); |
- std::vector<NetworkActionPredictorDatabase::Row::Id> ids_to_delete; |
+ std::vector<AutocompleteActionPredictorDatabase::Row::Id> ids_to_delete; |
DeleteOldIdsFromCaches(url_db, &ids_to_delete); |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::DeleteRows, db_, |
+ base::Bind(&AutocompleteActionPredictorDatabase::DeleteRows, db_, |
ids_to_delete)); |
// Register for notifications and set the |initialized_| flag. |
@@ -356,15 +360,15 @@ void NetworkActionPredictor::DeleteOldEntries(history::URLDatabase* url_db) { |
initialized_ = true; |
} |
-void NetworkActionPredictor::CreateCaches( |
- std::vector<NetworkActionPredictorDatabase::Row>* rows) { |
+void AutocompleteActionPredictor::CreateCaches( |
+ std::vector<AutocompleteActionPredictorDatabase::Row>* rows) { |
CHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
DCHECK(!initialized_); |
DCHECK(db_cache_.empty()); |
DCHECK(db_id_cache_.empty()); |
- for (std::vector<NetworkActionPredictorDatabase::Row>::const_iterator it = |
- rows->begin(); it != rows->end(); ++it) { |
+ for (std::vector<AutocompleteActionPredictorDatabase::Row>::const_iterator |
+ it = rows->begin(); it != rows->end(); ++it) { |
const DBCacheKey key = { it->user_text, it->url }; |
const DBCacheValue value = { it->number_of_hits, it->number_of_misses }; |
db_cache_[key] = value; |
@@ -382,7 +386,7 @@ void NetworkActionPredictor::CreateCaches( |
} |
} |
-bool NetworkActionPredictor::TryDeleteOldEntries(HistoryService* service) { |
+bool AutocompleteActionPredictor::TryDeleteOldEntries(HistoryService* service) { |
if (!service) |
return false; |
@@ -394,7 +398,7 @@ bool NetworkActionPredictor::TryDeleteOldEntries(HistoryService* service) { |
return true; |
} |
-double NetworkActionPredictor::CalculateConfidence( |
+double AutocompleteActionPredictor::CalculateConfidence( |
const string16& user_text, |
const AutocompleteMatch& match, |
bool* is_in_db) const { |
@@ -412,7 +416,7 @@ double NetworkActionPredictor::CalculateConfidence( |
return CalculateConfidenceForDbEntry(iter); |
} |
-double NetworkActionPredictor::CalculateConfidenceForDbEntry( |
+double AutocompleteActionPredictor::CalculateConfidenceForDbEntry( |
DBCacheMap::const_iterator iter) const { |
const DBCacheValue& value = iter->second; |
if (value.number_of_hits < kMinimumNumberOfHits) |
@@ -422,9 +426,9 @@ double NetworkActionPredictor::CalculateConfidenceForDbEntry( |
return number_of_hits / (number_of_hits + value.number_of_misses); |
} |
-void NetworkActionPredictor::AddRow( |
+void AutocompleteActionPredictor::AddRow( |
const DBCacheKey& key, |
- const NetworkActionPredictorDatabase::Row& row) { |
+ const AutocompleteActionPredictorDatabase::Row& row) { |
if (!initialized_) |
return; |
@@ -432,15 +436,15 @@ void NetworkActionPredictor::AddRow( |
db_cache_[key] = value; |
db_id_cache_[key] = row.id; |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::AddRow, db_, row)); |
+ base::Bind(&AutocompleteActionPredictorDatabase::AddRow, db_, row)); |
UMA_HISTOGRAM_ENUMERATION("NetworkActionPredictor.DatabaseAction", |
DATABASE_ACTION_ADD, DATABASE_ACTION_COUNT); |
} |
-void NetworkActionPredictor::UpdateRow( |
+void AutocompleteActionPredictor::UpdateRow( |
DBCacheMap::iterator it, |
- const NetworkActionPredictorDatabase::Row& row) { |
+ const AutocompleteActionPredictorDatabase::Row& row) { |
if (!initialized_) |
return; |
@@ -448,28 +452,29 @@ void NetworkActionPredictor::UpdateRow( |
it->second.number_of_hits = row.number_of_hits; |
it->second.number_of_misses = row.number_of_misses; |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::UpdateRow, db_, row)); |
+ base::Bind(&AutocompleteActionPredictorDatabase::UpdateRow, db_, row)); |
UMA_HISTOGRAM_ENUMERATION("NetworkActionPredictor.DatabaseAction", |
DATABASE_ACTION_UPDATE, DATABASE_ACTION_COUNT); |
} |
-void NetworkActionPredictor::DeleteAllRows() { |
+void AutocompleteActionPredictor::DeleteAllRows() { |
if (!initialized_) |
return; |
db_cache_.clear(); |
db_id_cache_.clear(); |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::DeleteAllRows, db_)); |
+ base::Bind(&AutocompleteActionPredictorDatabase::DeleteAllRows, db_)); |
UMA_HISTOGRAM_ENUMERATION("NetworkActionPredictor.DatabaseAction", |
DATABASE_ACTION_DELETE_ALL, DATABASE_ACTION_COUNT); |
} |
-void NetworkActionPredictor::DeleteRowsWithURLs(const history::URLRows& rows) { |
+void AutocompleteActionPredictor::DeleteRowsWithURLs( |
+ const history::URLRows& rows) { |
if (!initialized_) |
return; |
- std::vector<NetworkActionPredictorDatabase::Row::Id> id_list; |
+ std::vector<AutocompleteActionPredictorDatabase::Row::Id> id_list; |
for (DBCacheMap::iterator it = db_cache_.begin(); it != db_cache_.end();) { |
if (std::find_if(rows.begin(), rows.end(), |
@@ -485,29 +490,30 @@ void NetworkActionPredictor::DeleteRowsWithURLs(const history::URLRows& rows) { |
} |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::DeleteRows, db_, id_list)); |
+ base::Bind(&AutocompleteActionPredictorDatabase::DeleteRows, |
+ db_, id_list)); |
UMA_HISTOGRAM_ENUMERATION("NetworkActionPredictor.DatabaseAction", |
DATABASE_ACTION_DELETE_SOME, DATABASE_ACTION_COUNT); |
} |
-void NetworkActionPredictor::BeginTransaction() { |
+void AutocompleteActionPredictor::BeginTransaction() { |
if (!initialized_) |
return; |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::BeginTransaction, db_)); |
+ base::Bind(&AutocompleteActionPredictorDatabase::BeginTransaction, db_)); |
} |
-void NetworkActionPredictor::CommitTransaction() { |
+void AutocompleteActionPredictor::CommitTransaction() { |
if (!initialized_) |
return; |
content::BrowserThread::PostTask(content::BrowserThread::DB, FROM_HERE, |
- base::Bind(&NetworkActionPredictorDatabase::CommitTransaction, db_)); |
+ base::Bind(&AutocompleteActionPredictorDatabase::CommitTransaction, db_)); |
} |
-NetworkActionPredictor::TransitionalMatch::TransitionalMatch() { |
+AutocompleteActionPredictor::TransitionalMatch::TransitionalMatch() { |
} |
-NetworkActionPredictor::TransitionalMatch::~TransitionalMatch() { |
+AutocompleteActionPredictor::TransitionalMatch::~TransitionalMatch() { |
} |