Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(533)

Side by Side Diff: content/public/browser/download_manager.h

Issue 10915180: Make DownloadHistory observe manager, items (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: @r158560 Created 8 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 // The DownloadManager object manages the process of downloading, including 5 // The DownloadManager object manages the process of downloading, including
6 // updates to the history system and providing the information for displaying 6 // updates to the history system and providing the information for displaying
7 // the downloads view in the Destinations tab. There is one DownloadManager per 7 // the downloads view in the Destinations tab. There is one DownloadManager per
8 // active browser context in Chrome. 8 // active browser context in Chrome.
9 // 9 //
10 // Download observers: 10 // Download observers:
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
80 class CONTENT_EXPORT Observer { 80 class CONTENT_EXPORT Observer {
81 public: 81 public:
82 // A DownloadItem was created. Unlike ModelChanged, this item may be 82 // A DownloadItem was created. Unlike ModelChanged, this item may be
83 // visible before the filename is determined; in this case the return value 83 // visible before the filename is determined; in this case the return value
84 // of GetTargetFileName() will be null. This method may be called an 84 // of GetTargetFileName() will be null. This method may be called an
85 // arbitrary number of times, e.g. when loading history on startup. As a 85 // arbitrary number of times, e.g. when loading history on startup. As a
86 // result, consumers should avoid doing large amounts of work in 86 // result, consumers should avoid doing large amounts of work in
87 // OnDownloadCreated(). TODO(<whoever>): When we've fully specified the 87 // OnDownloadCreated(). TODO(<whoever>): When we've fully specified the
88 // possible states of the DownloadItem in download_item.h and removed 88 // possible states of the DownloadItem in download_item.h and removed
89 // ModelChanged, we should remove the caveat above. 89 // ModelChanged, we should remove the caveat above.
90 // DO NOT create another download synchronously in OnDownloadCreated().
90 virtual void OnDownloadCreated( 91 virtual void OnDownloadCreated(
91 DownloadManager* manager, DownloadItem* item) {} 92 DownloadManager* manager, DownloadItem* item) {}
92 93
93 // New or deleted download, observers should query us for the current set 94 // New or deleted download, observers should query us for the current set
94 // of downloads. 95 // of downloads.
95 virtual void ModelChanged(DownloadManager* manager) {} 96 virtual void ModelChanged(DownloadManager* manager) {}
96 97
97 // Called when the DownloadManager is being destroyed to prevent Observers 98 // Called when the DownloadManager is being destroyed to prevent Observers
98 // from calling back to a stale pointer. 99 // from calling back to a stale pointer.
99 virtual void ManagerGoingDown(DownloadManager* manager) {} 100 virtual void ManagerGoingDown(DownloadManager* manager) {}
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after
165 virtual void DownloadUrl(scoped_ptr<DownloadUrlParameters> parameters) = 0; 166 virtual void DownloadUrl(scoped_ptr<DownloadUrlParameters> parameters) = 0;
166 167
167 // Allow objects to observe the download creation process. 168 // Allow objects to observe the download creation process.
168 virtual void AddObserver(Observer* observer) = 0; 169 virtual void AddObserver(Observer* observer) = 0;
169 170
170 // Remove a download observer from ourself. 171 // Remove a download observer from ourself.
171 virtual void RemoveObserver(Observer* observer) = 0; 172 virtual void RemoveObserver(Observer* observer) = 0;
172 173
173 // Called by the embedder, after creating the download manager, to let it know 174 // Called by the embedder, after creating the download manager, to let it know
174 // about downloads from previous runs of the browser. 175 // about downloads from previous runs of the browser.
175 virtual void OnPersistentStoreQueryComplete( 176 virtual DownloadItem* CreateDownloadItem(
176 std::vector<DownloadPersistentStoreInfo>* entries) = 0; 177 const FilePath& path,
177 178 const GURL& url,
178 // Called by the embedder, in response to 179 const GURL& referrer_url,
179 // DownloadManagerDelegate::AddItemToPersistentStore. 180 const base::Time& start_time,
180 virtual void OnItemAddedToPersistentStore(int32 download_id, 181 const base::Time& end_time,
181 int64 db_handle) = 0; 182 int64 received_bytes,
183 int64 total_bytes,
184 DownloadItem::DownloadState state,
185 bool opened) = 0;
182 186
183 // The number of in progress (including paused) downloads. 187 // The number of in progress (including paused) downloads.
184 virtual int InProgressCount() const = 0; 188 virtual int InProgressCount() const = 0;
185 189
186 virtual BrowserContext* GetBrowserContext() const = 0; 190 virtual BrowserContext* GetBrowserContext() const = 0;
187 191
188 // Checks whether downloaded files still exist. Updates state of downloads 192 // Checks whether downloaded files still exist. Updates state of downloads
189 // that refer to removed files. The check runs in the background and may 193 // that refer to removed files. The check runs in the background and may
190 // finish asynchronously after this method returns. 194 // finish asynchronously after this method returns.
191 virtual void CheckForHistoryFilesRemoval() = 0; 195 virtual void CheckForHistoryFilesRemoval() = 0;
192 196
193 // Get the download item from the history map. Useful after the item has 197 // Get the download item from the history map. Useful after the item has
194 // been removed from the active map, or was retrieved from the history DB. 198 // been removed from the active map, or was retrieved from the history DB.
195 virtual DownloadItem* GetDownloadItem(int id) = 0; 199 virtual DownloadItem* GetDownloadItem(int id) = 0;
196 200
197 // Get the download item for |id| if present, no matter what type of download 201 // Get the download item for |id| if present, no matter what type of download
198 // it is or state it's in. 202 // it is or state it's in.
199 virtual DownloadItem* GetDownload(int id) = 0; 203 virtual DownloadItem* GetDownload(int id) = 0;
200 204
201 // Called when Save Page download is done.
202 virtual void SavePageDownloadFinished(DownloadItem* download) = 0;
203
204 // Get the download item from the active map. Useful when the item is not 205 // Get the download item from the active map. Useful when the item is not
205 // yet in the history map. 206 // yet in the history map.
206 virtual DownloadItem* GetActiveDownloadItem(int id) = 0; 207 virtual DownloadItem* GetActiveDownloadItem(int id) = 0;
207 208
208 protected: 209 protected:
209 virtual ~DownloadManager() {} 210 virtual ~DownloadManager() {}
210 211
211 private: 212 private:
212 friend class base::RefCountedThreadSafe<DownloadManager>; 213 friend class base::RefCountedThreadSafe<DownloadManager>;
213 }; 214 };
214 215
215 } // namespace content 216 } // namespace content
216 217
217 #endif // CONTENT_PUBLIC_BROWSER_DOWNLOAD_MANAGER_H_ 218 #endif // CONTENT_PUBLIC_BROWSER_DOWNLOAD_MANAGER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698