Index: content/browser/download/download_resource_handler.h |
diff --git a/content/browser/download/download_resource_handler.h b/content/browser/download/download_resource_handler.h |
index 66b69b761b1ca2da65da6487b0c00fdf5c297072..ef9254f1f76e942f64cc39b056856762cd9321a3 100644 |
--- a/content/browser/download/download_resource_handler.h |
+++ b/content/browser/download/download_resource_handler.h |
@@ -24,7 +24,8 @@ class DownloadRequestHandle; |
struct DownloadCreateInfo; |
namespace content { |
-class DownloadBuffer; |
+class ByteStreamWriter; |
+class ByteStreamReader; |
} |
namespace net { |
@@ -36,17 +37,16 @@ class DownloadResourceHandler : public ResourceHandler { |
public: |
typedef content::DownloadUrlParameters::OnStartedCallback OnStartedCallback; |
- static const size_t kLoadsToWrite = 100; // number of data buffers queued |
- |
// started_cb will be called exactly once on the UI thread. |
- DownloadResourceHandler(int render_process_host_id, |
- int render_view_id, |
- int request_id, |
- const GURL& url, |
- DownloadFileManager* download_file_manager, |
- net::URLRequest* request, |
- const OnStartedCallback& started_cb, |
- const content::DownloadSaveInfo& save_info); |
+ DownloadResourceHandler( |
+ int render_process_host_id, |
+ int render_view_id, |
+ int request_id, |
+ const GURL& url, |
+ scoped_refptr<DownloadFileManager> download_file_manager, |
+ net::URLRequest* request, |
+ const OnStartedCallback& started_cb, |
+ const content::DownloadSaveInfo& save_info); |
virtual bool OnUploadProgress(int request_id, |
uint64 position, |
@@ -92,21 +92,11 @@ class DownloadResourceHandler : public ResourceHandler { |
private: |
virtual ~DownloadResourceHandler(); |
- void OnResponseCompletedInternal(int request_id, |
- const net::URLRequestStatus& status, |
- const std::string& security_info, |
- int response_code); |
- |
- void CheckWriteProgressLater(); |
- void CheckWriteProgress(); |
- void MaybeResumeRequest(); |
+ // Arrange for started_cb_ to be called on the UI thread with the |
+ // below values, nulling out started_cb_. Should only be called |
+ // on the IO thread. |
void CallStartedCB(content::DownloadId id, net::Error error); |
- // Generates a DownloadId and calls DownloadFileManager. |
- void StartOnUIThread(scoped_ptr<DownloadCreateInfo> info, |
- const DownloadRequestHandle& handle); |
- void SetDownloadID(content::DownloadId id); |
- |
// If the content-length header is not present (or contains something other |
// than numbers), the incoming content_length is -1 (unknown size). |
// Set the content length to 0 to indicate unknown size to DownloadManager. |
@@ -114,23 +104,26 @@ class DownloadResourceHandler : public ResourceHandler { |
void SetContentDisposition(const std::string& content_disposition); |
- content::DownloadId download_id_; |
content::GlobalRequestID global_id_; |
int render_view_id_; |
- scoped_refptr<net::IOBuffer> read_buffer_; |
std::string content_disposition_; |
int64 content_length_; |
- DownloadFileManager* download_file_manager_; |
+ scoped_refptr<DownloadFileManager> download_file_manager_; |
net::URLRequest* request_; |
- // This is used only on the UI thread. |
+ // This is read only on the IO thread, but may only |
+ // be called on the UI thread. |
OnStartedCallback started_cb_; |
content::DownloadSaveInfo save_info_; |
- scoped_refptr<content::DownloadBuffer> buffer_; |
- base::OneShotTimer<DownloadResourceHandler> check_write_progress_timer_; |
+ |
+ // Data flow |
+ scoped_refptr<net::IOBuffer> read_buffer_; // From URLRequest. |
+ scoped_ptr<content::ByteStreamWriter> stream_writer_; // To rest of system. |
// The following are used to collect stats. |
base::TimeTicks download_start_time_; |
base::TimeTicks last_read_time_; |
+ base::TimeTicks last_stream_pause_time_; |
+ base::TimeDelta total_pause_time_; |
size_t last_buffer_size_; |
int64 bytes_read_; |
std::string accept_ranges_; |