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 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
45 | 45 |
46 static const int kFileOpenFlags = base::PLATFORM_FILE_OPEN | | 46 static const int kFileOpenFlags = base::PLATFORM_FILE_OPEN | |
47 base::PLATFORM_FILE_READ | | 47 base::PLATFORM_FILE_READ | |
48 base::PLATFORM_FILE_ASYNC; | 48 base::PLATFORM_FILE_ASYNC; |
49 | 49 |
50 BlobURLRequestJob::BlobURLRequestJob( | 50 BlobURLRequestJob::BlobURLRequestJob( |
51 net::URLRequest* request, | 51 net::URLRequest* request, |
52 BlobData* blob_data, | 52 BlobData* blob_data, |
53 base::MessageLoopProxy* file_thread_proxy) | 53 base::MessageLoopProxy* file_thread_proxy) |
54 : net::URLRequestJob(request), | 54 : net::URLRequestJob(request), |
55 ALLOW_THIS_IN_INITIALIZER_LIST(callback_factory_(this)), | |
56 ALLOW_THIS_IN_INITIALIZER_LIST(weak_factory_(this)), | 55 ALLOW_THIS_IN_INITIALIZER_LIST(weak_factory_(this)), |
57 blob_data_(blob_data), | 56 blob_data_(blob_data), |
58 file_thread_proxy_(file_thread_proxy), | 57 file_thread_proxy_(file_thread_proxy), |
59 item_index_(0), | 58 item_index_(0), |
60 total_size_(0), | 59 total_size_(0), |
61 current_item_offset_(0), | 60 current_item_offset_(0), |
62 remaining_bytes_(0), | 61 remaining_bytes_(0), |
63 read_buf_offset_(0), | 62 read_buf_offset_(0), |
64 read_buf_size_(0), | 63 read_buf_size_(0), |
65 read_buf_remaining_bytes_(0), | 64 read_buf_remaining_bytes_(0), |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 if (stream_ != NULL) { | 103 if (stream_ != NULL) { |
105 stream_->Close(); | 104 stream_->Close(); |
106 stream_.reset(NULL); | 105 stream_.reset(NULL); |
107 } | 106 } |
108 } | 107 } |
109 | 108 |
110 void BlobURLRequestJob::Kill() { | 109 void BlobURLRequestJob::Kill() { |
111 CloseStream(); | 110 CloseStream(); |
112 | 111 |
113 net::URLRequestJob::Kill(); | 112 net::URLRequestJob::Kill(); |
114 callback_factory_.RevokeAll(); | |
115 weak_factory_.InvalidateWeakPtrs(); | 113 weak_factory_.InvalidateWeakPtrs(); |
116 method_factory_.RevokeAll(); | 114 method_factory_.RevokeAll(); |
117 } | 115 } |
118 | 116 |
119 void BlobURLRequestJob::ResolveFile(const FilePath& file_path) { | 117 void BlobURLRequestJob::ResolveFile(const FilePath& file_path) { |
120 base::FileUtilProxy::GetFileInfo( | 118 base::FileUtilProxy::GetFileInfo( |
121 file_thread_proxy_, | 119 file_thread_proxy_, file_path, |
122 file_path, | 120 base::Bind(&BlobURLRequestJob::DidResolve, weak_factory_.GetWeakPtr())); |
123 callback_factory_.NewCallback(&BlobURLRequestJob::DidResolve)); | |
124 } | 121 } |
125 | 122 |
126 void BlobURLRequestJob::DidResolve(base::PlatformFileError rv, | 123 void BlobURLRequestJob::DidResolve(base::PlatformFileError rv, |
127 const base::PlatformFileInfo& file_info) { | 124 const base::PlatformFileInfo& file_info) { |
128 // If an error occured, bail out. | 125 // If an error occured, bail out. |
129 if (rv == base::PLATFORM_FILE_ERROR_NOT_FOUND) { | 126 if (rv == base::PLATFORM_FILE_ERROR_NOT_FOUND) { |
130 NotifyFailure(net::ERR_FILE_NOT_FOUND); | 127 NotifyFailure(net::ERR_FILE_NOT_FOUND); |
131 return; | 128 return; |
132 } else if (rv != base::PLATFORM_FILE_OK) { | 129 } else if (rv != base::PLATFORM_FILE_OK) { |
133 NotifyFailure(net::ERR_FAILED); | 130 NotifyFailure(net::ERR_FAILED); |
(...skipping 429 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
563 // We don't support multiple range requests in one single URL request, | 560 // We don't support multiple range requests in one single URL request, |
564 // because we need to do multipart encoding here. | 561 // because we need to do multipart encoding here. |
565 // TODO(jianli): Support multipart byte range requests. | 562 // TODO(jianli): Support multipart byte range requests. |
566 NotifyFailure(net::ERR_REQUEST_RANGE_NOT_SATISFIABLE); | 563 NotifyFailure(net::ERR_REQUEST_RANGE_NOT_SATISFIABLE); |
567 } | 564 } |
568 } | 565 } |
569 } | 566 } |
570 } | 567 } |
571 | 568 |
572 } // namespace webkit_blob | 569 } // namespace webkit_blob |
OLD | NEW |