OLD | NEW |
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 #include "chrome/browser/download/download_path_reservation_tracker.h" | 5 #include "chrome/browser/download/download_path_reservation_tracker.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/callback.h" | 8 #include "base/callback.h" |
9 #include "base/file_util.h" | 9 #include "base/file_util.h" |
10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
(...skipping 18 matching lines...) Expand all Loading... |
29 public: | 29 public: |
30 DownloadItemObserver(DownloadItem& download_item, | 30 DownloadItemObserver(DownloadItem& download_item, |
31 base::Closure revoke, | 31 base::Closure revoke, |
32 base::Callback<void(const FilePath&)> update); | 32 base::Callback<void(const FilePath&)> update); |
33 | 33 |
34 private: | 34 private: |
35 virtual ~DownloadItemObserver(); | 35 virtual ~DownloadItemObserver(); |
36 | 36 |
37 // DownloadItem::Observer | 37 // DownloadItem::Observer |
38 virtual void OnDownloadUpdated(DownloadItem* download) OVERRIDE; | 38 virtual void OnDownloadUpdated(DownloadItem* download) OVERRIDE; |
39 virtual void OnDownloadOpened(DownloadItem* download) OVERRIDE; | 39 virtual void OnDownloadDestroyed(DownloadItem* download) OVERRIDE; |
40 | 40 |
41 DownloadItem& download_item_; | 41 DownloadItem& download_item_; |
42 | 42 |
43 // Last known target path for the download. | 43 // Last known target path for the download. |
44 FilePath last_target_path_; | 44 FilePath last_target_path_; |
45 | 45 |
46 // Callback to invoke to revoke the path reseration. | 46 // Callback to invoke to revoke the path reseration. |
47 base::Closure revoke_callback_; | 47 base::Closure revoke_callback_; |
48 | 48 |
49 // Callback to invoke to update the path reservation. | 49 // Callback to invoke to update the path reservation. |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
82 } | 82 } |
83 | 83 |
84 case DownloadItem::COMPLETE: | 84 case DownloadItem::COMPLETE: |
85 // If the download is complete, then it has already been renamed to the | 85 // If the download is complete, then it has already been renamed to the |
86 // final name. The existence of the file on disk is sufficient to prevent | 86 // final name. The existence of the file on disk is sufficient to prevent |
87 // conflicts from now on. | 87 // conflicts from now on. |
88 | 88 |
89 case DownloadItem::CANCELLED: | 89 case DownloadItem::CANCELLED: |
90 // We no longer need the reservation if the download is being removed. | 90 // We no longer need the reservation if the download is being removed. |
91 | 91 |
92 case DownloadItem::REMOVING: | |
93 // Ditto, but this case shouldn't happen in practice. We should have | |
94 // received another notification beforehand. | |
95 | |
96 case DownloadItem::INTERRUPTED: | 92 case DownloadItem::INTERRUPTED: |
97 // The download filename will need to be re-generated when the download is | 93 // The download filename will need to be re-generated when the download is |
98 // restarted. Holding on to the reservation now would prevent the name | 94 // restarted. Holding on to the reservation now would prevent the name |
99 // from being used for a subsequent retry attempt. | 95 // from being used for a subsequent retry attempt. |
100 | 96 |
101 BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE, revoke_callback_); | 97 BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE, revoke_callback_); |
102 delete this; | 98 delete this; |
103 break; | 99 break; |
104 | 100 |
105 case DownloadItem::MAX_DOWNLOAD_STATE: | 101 case DownloadItem::MAX_DOWNLOAD_STATE: |
106 // Compiler appeasement. | 102 // Compiler appeasement. |
107 NOTREACHED(); | 103 NOTREACHED(); |
108 } | 104 } |
109 } | 105 } |
110 | 106 |
111 void DownloadItemObserver::OnDownloadOpened(DownloadItem* download) { | 107 void DownloadItemObserver::OnDownloadDestroyed(DownloadItem* download) { |
112 // We shouldn't be tracking reservations for a download that has been | 108 // This shouldn't happen. We should catch either COMPLETE, CANCELLED, or |
113 // externally opened. The tracker should have detached itself when the | 109 // INTERRUPTED first. |
114 // download was complete. | 110 BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE, revoke_callback_); |
| 111 delete this; |
115 } | 112 } |
116 | 113 |
117 } // namespace | 114 } // namespace |
118 | 115 |
119 // static | 116 // static |
120 void DownloadPathReservationTracker::GetReservedPath( | 117 void DownloadPathReservationTracker::GetReservedPath( |
121 DownloadItem& download_item, | 118 DownloadItem& download_item, |
122 const FilePath& target_path, | 119 const FilePath& target_path, |
123 const FilePath& default_path, | 120 const FilePath& default_path, |
124 bool uniquify_path, | 121 bool uniquify_path, |
(...skipping 124 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
249 reservations_.erase(download_id); | 246 reservations_.erase(download_id); |
250 } | 247 } |
251 | 248 |
252 // static | 249 // static |
253 DownloadPathReservationTracker* DownloadPathReservationTracker::GetInstance() { | 250 DownloadPathReservationTracker* DownloadPathReservationTracker::GetInstance() { |
254 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 251 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
255 static base::LazyInstance<DownloadPathReservationTracker> | 252 static base::LazyInstance<DownloadPathReservationTracker> |
256 reservation_tracker = LAZY_INSTANCE_INITIALIZER; | 253 reservation_tracker = LAZY_INSTANCE_INITIALIZER; |
257 return reservation_tracker.Pointer(); | 254 return reservation_tracker.Pointer(); |
258 } | 255 } |
OLD | NEW |