| Index: chrome/browser/history/download_database.h | 
| diff --git a/chrome/browser/history/download_database.h b/chrome/browser/history/download_database.h | 
| index f5e18bdfbbf052c255c5a7aec5f5884b0b4143b8..9f20d073e92fd4571cb1938e527528d6c0a67a49 100644 | 
| --- a/chrome/browser/history/download_database.h | 
| +++ b/chrome/browser/history/download_database.h | 
| @@ -13,10 +13,7 @@ | 
| #include "sql/meta_table.h" | 
|  | 
| class FilePath; | 
| - | 
| -namespace content { | 
| struct DownloadPersistentStoreInfo; | 
| -} | 
|  | 
| namespace sql { | 
| class Connection; | 
| @@ -27,6 +24,10 @@ namespace history { | 
| // Maintains a table of downloads. | 
| class DownloadDatabase { | 
| public: | 
| +  // The value of |db_handle| indicating that the associated DownloadItem is not | 
| +  // yet persisted. | 
| +  static const int64 kUninitializedHandle; | 
| + | 
| // Must call InitDownloadTable before using any other functions. | 
| DownloadDatabase(); | 
| virtual ~DownloadDatabase(); | 
| @@ -35,15 +36,12 @@ class DownloadDatabase { | 
|  | 
| // Get all the downloads from the database. | 
| void QueryDownloads( | 
| -      std::vector<content::DownloadPersistentStoreInfo>* results); | 
| +      std::vector<DownloadPersistentStoreInfo>* results); | 
|  | 
| // Update the state of one download. Returns true if successful. | 
| -  // Does not update |url|, |start_time|, |total_bytes|; uses |db_handle| only | 
| +  // Does not update |url|, |start_time|; uses |db_handle| only | 
| // to select the row in the database table to update. | 
| -  bool UpdateDownload(const content::DownloadPersistentStoreInfo& data); | 
| - | 
| -  // Update the path of one download. Returns true if successful. | 
| -  bool UpdateDownloadPath(const FilePath& path, DownloadID db_handle); | 
| +  bool UpdateDownload(const DownloadPersistentStoreInfo& data); | 
|  | 
| // Fixes state of the download entries. Sometimes entries with IN_PROGRESS | 
| // state are not updated during browser shutdown (particularly when crashing). | 
| @@ -52,16 +50,10 @@ class DownloadDatabase { | 
| bool CleanUpInProgressEntries(); | 
|  | 
| // Create a new database entry for one download and return its primary db id. | 
| -  int64 CreateDownload(const content::DownloadPersistentStoreInfo& info); | 
| +  int64 CreateDownload(const DownloadPersistentStoreInfo& info); | 
|  | 
| -  // Remove a download from the database. | 
| -  void RemoveDownload(DownloadID db_handle); | 
| - | 
| -  // Remove all completed downloads that started after |remove_begin| | 
| -  // (inclusive) and before |remove_end|. You may use null Time values | 
| -  // to do an unbounded delete in either direction. This function ignores | 
| -  // all downloads that are in progress or are waiting to be cancelled. | 
| -  bool RemoveDownloadsBetween(base::Time remove_begin, base::Time remove_end); | 
| +  // Remove all |handles| from the database. | 
| +  void RemoveDownloads(const std::set<int64>& handles); | 
|  | 
| protected: | 
| // Returns the database for the functions in this interface. | 
| @@ -83,11 +75,10 @@ class DownloadDatabase { | 
| bool DropDownloadTable(); | 
|  | 
| private: | 
| -  // TODO(rdsmith): Remove after http://crbug.com/96627 has been resolved. | 
| -  void CheckThread(); | 
| - | 
| bool EnsureColumnExists(const std::string& name, const std::string& type); | 
|  | 
| +  int CountDownloads(); | 
| + | 
| bool owning_thread_set_; | 
| base::PlatformThreadId owning_thread_; | 
|  | 
|  |