Chromium Code Reviews| Index: chrome/browser/predictors/predictor_database.h |
| diff --git a/chrome/browser/predictors/predictor_database.h b/chrome/browser/predictors/predictor_database.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..e3bd51b3dd2c21559b7010e90da3896f82ada641 |
| --- /dev/null |
| +++ b/chrome/browser/predictors/predictor_database.h |
| @@ -0,0 +1,147 @@ |
| +// Copyright (c) 2011 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. |
| + |
| +#ifndef CHROME_BROWSER_PREDICTORS_PREDICTOR_DATABASE_H_ |
| +#define CHROME_BROWSER_PREDICTORS_PREDICTOR_DATABASE_H_ |
| +#pragma once |
| + |
| +#include <string> |
| +#include <vector> |
| + |
| +#include "base/file_path.h" |
| +#include "base/memory/ref_counted.h" |
| +#include "base/string16.h" |
| +#include "base/synchronization/cancellation_flag.h" |
| +#include "chrome/browser/profiles/refcounted_profile_keyed_service.h" |
| +#include "googleurl/src/gurl.h" |
| +#include "sql/connection.h" |
| + |
| +class Profile; |
| + |
| +namespace predictors { |
| + |
| +// Refcounted as it is created and destroyed in the UI thread, but its database |
| +// related functions have to be called in the DB thread. |
| +class PredictorTableBase |
|
dominich
2012/03/13 14:55:21
this should be in its own file.
Shishir
2012/03/14 21:14:37
Done.
|
| + : public base::RefCountedThreadSafe<PredictorTableBase> { |
| + protected: |
| + PredictorTableBase(); |
| + virtual ~PredictorTableBase(); |
| + virtual void CreateTableIfNonExistent() = 0; |
| + |
| + sql::Connection* db_; |
|
dominich
2012/03/13 14:55:21
if each table has its own pointer to the same data
Shishir
2012/03/14 21:14:37
Done.
|
| + base::CancellationFlag cancelled_; |
| + |
| + private: |
| + friend class PredictorDatabase; |
| + friend class base::RefCountedThreadSafe<PredictorTableBase>; |
| + |
| + void Initialize(sql::Connection* db); |
| + |
| + DISALLOW_COPY_AND_ASSIGN(PredictorTableBase); |
| +}; |
| + |
| + |
| +// This manages the autocomplete predictor table within the SQLite database |
| +// passed in to the constructor. It expects the following scheme: |
| +// |
| +// network_action_predictor |
| +// id A unique id. |
| +// user_text What the user typed. |
| +// url The URL of the entry. |
| +// number_of_hits Number of times the entry was shown to the user and |
| +// selected. |
| +// number_of_misses Number of times the entry was shown to the user but not |
| +// selected. |
| +// |
| +// TODO(dominich): Consider adding this table to one of the history databases. |
| +// In memory is currently used, but adding to the on-disk visits database |
| +// would allow DeleteOldEntries to be cheaper through use of a join. |
| +class AutocompleteActionPredictorTable : public PredictorTableBase { |
|
dominich
2012/03/13 14:55:21
this should be in its own file.
Shishir
2012/03/14 21:14:37
Done.
|
| + public: |
| + struct Row { |
| + // TODO(dominich): Make this 64-bit integer as an optimization. This |
| + // requires some investigation into how to make sure the id is unique for |
| + // each user_text/url pair. |
| + // http://crbug.com/102020 |
| + typedef std::string Id; |
| + |
| + Row(); |
| + |
| + // Only used by unit tests. |
| + Row(const Id& id, |
| + const string16& user_text, |
| + const GURL& url, |
| + int number_of_hits, |
| + int number_of_misses); |
| + |
| + Row(const Row& row); |
| + |
| + Id id; |
| + string16 user_text; |
| + GURL url; |
| + int number_of_hits; |
| + int number_of_misses; |
| + }; |
| + |
| + typedef std::vector<Row> Rows; |
| + |
| + void GetRow(const Row::Id& id, Row* row); |
| + void GetAllRows(Rows* row_buffer); |
| + |
| + void AddRow(const Row& row); |
| + void UpdateRow(const Row& row); |
| + void AddAndUpdateRows(const Rows& rows_to_add, const Rows& rows_to_update); |
| + void DeleteRow(const Row::Id& id); |
| + void DeleteRows(const std::vector<Row::Id>& id_list); |
| + void DeleteAllRows(); |
| + |
| + private: |
| + friend class PredictorDatabase; |
| + |
| + AutocompleteActionPredictorTable(); |
| + virtual ~AutocompleteActionPredictorTable(); |
| + |
| + void CreateTableIfNonExistent() OVERRIDE; |
| + |
| + bool StepAndInitializeRow(sql::Statement* statement, Row* row); |
| + void BindRowToStatement(const Row& row, sql::Statement* statement); |
| + |
| + DISALLOW_COPY_AND_ASSIGN(AutocompleteActionPredictorTable); |
| +}; |
| + |
| + |
| +// RefcountedProfileKeyedService as it is created and destroyed on a different |
| +// thread to the DB thread that is required for all methods performing database |
| +// access. |
| +class PredictorDatabase : public RefcountedProfileKeyedService { |
| + public: |
| + explicit PredictorDatabase(Profile* profile); |
| + virtual ~PredictorDatabase(); |
| + |
| + // Opens the database file from the profile path. Separated from the |
| + // constructor to ease construction/destruction of this object on one thread |
| + // but database access on the DB thread. |
| + void Initialize(); |
| + |
| + AutocompleteActionPredictorTable* autocomplete_table() { |
| + return autocomplete_table_.get(); |
| + } |
| + |
| + private: |
| + friend class AutocompleteActionPredictorTableTest; |
| + |
| + // RefcountedProfileKeyedService. |
| + virtual void ShutdownOnUIThread() OVERRIDE; |
| + |
| + FilePath db_path_; |
| + sql::Connection db_; |
| + scoped_refptr<AutocompleteActionPredictorTable> autocomplete_table_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(PredictorDatabase); |
| +}; |
| + |
| +} // namespace predictors |
| + |
| +#endif // CHROME_BROWSER_PREDICTORS_PREDICTOR_DATABASE_H_ |