| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "content/browser/streams/stream.h" | 5 #include "content/browser/streams/stream.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/location.h" | 8 #include "base/location.h" |
| 9 #include "base/message_loop/message_loop_proxy.h" | 9 #include "base/message_loop/message_loop_proxy.h" |
| 10 #include "content/browser/streams/stream_handle_impl.h" | 10 #include "content/browser/streams/stream_handle_impl.h" |
| (...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 151 buf_size : remaining_bytes; | 151 buf_size : remaining_bytes; |
| 152 memcpy(buf->data(), data_->data() + data_bytes_read_, to_read); | 152 memcpy(buf->data(), data_->data() + data_bytes_read_, to_read); |
| 153 data_bytes_read_ += to_read; | 153 data_bytes_read_ += to_read; |
| 154 if (data_bytes_read_ >= data_length_) | 154 if (data_bytes_read_ >= data_length_) |
| 155 ClearBuffer(); | 155 ClearBuffer(); |
| 156 | 156 |
| 157 *bytes_read = to_read; | 157 *bytes_read = to_read; |
| 158 return STREAM_HAS_DATA; | 158 return STREAM_HAS_DATA; |
| 159 } | 159 } |
| 160 | 160 |
| 161 scoped_ptr<StreamHandle> Stream::CreateHandle(const GURL& original_url, | 161 scoped_ptr<StreamHandle> Stream::CreateHandle( |
| 162 const std::string& mime_type) { | 162 const GURL& original_url, |
| 163 const std::string& mime_type, |
| 164 const std::string& response_headers) { |
| 163 CHECK(!stream_handle_); | 165 CHECK(!stream_handle_); |
| 164 stream_handle_ = new StreamHandleImpl(weak_ptr_factory_.GetWeakPtr(), | 166 stream_handle_ = new StreamHandleImpl(weak_ptr_factory_.GetWeakPtr(), |
| 165 original_url, | 167 original_url, |
| 166 mime_type); | 168 mime_type, |
| 169 response_headers); |
| 167 return scoped_ptr<StreamHandle>(stream_handle_).Pass(); | 170 return scoped_ptr<StreamHandle>(stream_handle_).Pass(); |
| 168 } | 171 } |
| 169 | 172 |
| 170 void Stream::CloseHandle() { | 173 void Stream::CloseHandle() { |
| 171 // Prevent deletion until this function ends. | 174 // Prevent deletion until this function ends. |
| 172 scoped_refptr<Stream> ref(this); | 175 scoped_refptr<Stream> ref(this); |
| 173 | 176 |
| 174 CHECK(stream_handle_); | 177 CHECK(stream_handle_); |
| 175 stream_handle_ = NULL; | 178 stream_handle_ = NULL; |
| 176 registry_->UnregisterStream(url()); | 179 registry_->UnregisterStream(url()); |
| (...skipping 12 matching lines...) Expand all Loading... |
| 189 read_observer_->OnDataAvailable(this); | 192 read_observer_->OnDataAvailable(this); |
| 190 } | 193 } |
| 191 | 194 |
| 192 void Stream::ClearBuffer() { | 195 void Stream::ClearBuffer() { |
| 193 data_ = NULL; | 196 data_ = NULL; |
| 194 data_length_ = 0; | 197 data_length_ = 0; |
| 195 data_bytes_read_ = 0; | 198 data_bytes_read_ = 0; |
| 196 } | 199 } |
| 197 | 200 |
| 198 } // namespace content | 201 } // namespace content |
| OLD | NEW |