| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "webkit/blob/blob_url_request_job.h" | 5 #include "webkit/blob/blob_url_request_job.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
| 9 #include "base/file_path.h" | 9 #include "base/file_path.h" |
| 10 #include "base/file_util.h" | 10 #include "base/file_util.h" |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 58 item_index_(0), | 58 item_index_(0), |
| 59 total_size_(0), | 59 total_size_(0), |
| 60 current_item_offset_(0), | 60 current_item_offset_(0), |
| 61 remaining_bytes_(0), | 61 remaining_bytes_(0), |
| 62 read_buf_offset_(0), | 62 read_buf_offset_(0), |
| 63 read_buf_size_(0), | 63 read_buf_size_(0), |
| 64 read_buf_remaining_bytes_(0), | 64 read_buf_remaining_bytes_(0), |
| 65 bytes_to_read_(0), | 65 bytes_to_read_(0), |
| 66 error_(false), | 66 error_(false), |
| 67 headers_set_(false), | 67 headers_set_(false), |
| 68 byte_range_set_(false), | 68 byte_range_set_(false) { |
| 69 ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) { | |
| 70 DCHECK(file_thread_proxy_); | 69 DCHECK(file_thread_proxy_); |
| 71 } | 70 } |
| 72 | 71 |
| 73 BlobURLRequestJob::~BlobURLRequestJob() { | 72 BlobURLRequestJob::~BlobURLRequestJob() { |
| 74 // FileStream's destructor won't close it for us because we passed in our own | 73 // FileStream's destructor won't close it for us because we passed in our own |
| 75 // file handle. | 74 // file handle. |
| 76 CloseStream(); | 75 CloseStream(); |
| 77 } | 76 } |
| 78 | 77 |
| 79 void BlobURLRequestJob::Start() { | 78 void BlobURLRequestJob::Start() { |
| 80 // Continue asynchronously. | 79 // Continue asynchronously. |
| 81 MessageLoop::current()->PostTask( | 80 MessageLoop::current()->PostTask( |
| 82 FROM_HERE, | 81 FROM_HERE, |
| 83 method_factory_.NewRunnableMethod(&BlobURLRequestJob::DidStart)); | 82 base::Bind(&BlobURLRequestJob::DidStart, |
| 83 weak_factory_.GetWeakPtr())); |
| 84 } | 84 } |
| 85 | 85 |
| 86 void BlobURLRequestJob::DidStart() { | 86 void BlobURLRequestJob::DidStart() { |
| 87 // We only support GET request per the spec. | 87 // We only support GET request per the spec. |
| 88 if (request()->method() != "GET") { | 88 if (request()->method() != "GET") { |
| 89 NotifyFailure(net::ERR_METHOD_NOT_SUPPORTED); | 89 NotifyFailure(net::ERR_METHOD_NOT_SUPPORTED); |
| 90 return; | 90 return; |
| 91 } | 91 } |
| 92 | 92 |
| 93 // If the blob data is not present, bail out. | 93 // If the blob data is not present, bail out. |
| (...skipping 10 matching lines...) Expand all Loading... |
| 104 stream_->Close(); | 104 stream_->Close(); |
| 105 stream_.reset(NULL); | 105 stream_.reset(NULL); |
| 106 } | 106 } |
| 107 } | 107 } |
| 108 | 108 |
| 109 void BlobURLRequestJob::Kill() { | 109 void BlobURLRequestJob::Kill() { |
| 110 CloseStream(); | 110 CloseStream(); |
| 111 | 111 |
| 112 net::URLRequestJob::Kill(); | 112 net::URLRequestJob::Kill(); |
| 113 weak_factory_.InvalidateWeakPtrs(); | 113 weak_factory_.InvalidateWeakPtrs(); |
| 114 method_factory_.RevokeAll(); | |
| 115 } | 114 } |
| 116 | 115 |
| 117 void BlobURLRequestJob::ResolveFile(const FilePath& file_path) { | 116 void BlobURLRequestJob::ResolveFile(const FilePath& file_path) { |
| 118 base::FileUtilProxy::GetFileInfo( | 117 base::FileUtilProxy::GetFileInfo( |
| 119 file_thread_proxy_, file_path, | 118 file_thread_proxy_, file_path, |
| 120 base::Bind(&BlobURLRequestJob::DidResolve, weak_factory_.GetWeakPtr())); | 119 base::Bind(&BlobURLRequestJob::DidResolve, weak_factory_.GetWeakPtr())); |
| 121 } | 120 } |
| 122 | 121 |
| 123 void BlobURLRequestJob::DidResolve(base::PlatformFileError rv, | 122 void BlobURLRequestJob::DidResolve(base::PlatformFileError rv, |
| 124 const base::PlatformFileInfo& file_info) { | 123 const base::PlatformFileInfo& file_info) { |
| (...skipping 435 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 560 // We don't support multiple range requests in one single URL request, | 559 // We don't support multiple range requests in one single URL request, |
| 561 // because we need to do multipart encoding here. | 560 // because we need to do multipart encoding here. |
| 562 // TODO(jianli): Support multipart byte range requests. | 561 // TODO(jianli): Support multipart byte range requests. |
| 563 NotifyFailure(net::ERR_REQUEST_RANGE_NOT_SATISFIABLE); | 562 NotifyFailure(net::ERR_REQUEST_RANGE_NOT_SATISFIABLE); |
| 564 } | 563 } |
| 565 } | 564 } |
| 566 } | 565 } |
| 567 } | 566 } |
| 568 | 567 |
| 569 } // namespace webkit_blob | 568 } // namespace webkit_blob |
| OLD | NEW |