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 "net/quic/quic_chromium_client_stream.h" | 5 #include "net/quic/quic_chromium_client_stream.h" |
6 | 6 |
7 #include "base/callback_helpers.h" | 7 #include "base/callback_helpers.h" |
8 #include "base/location.h" | 8 #include "base/location.h" |
9 #include "base/thread_task_runner_handle.h" | 9 #include "base/thread_task_runner_handle.h" |
10 #include "net/base/io_buffer.h" | 10 #include "net/base/io_buffer.h" |
(...skipping 17 matching lines...) Expand all Loading... |
28 weak_factory_(this) {} | 28 weak_factory_(this) {} |
29 | 29 |
30 QuicChromiumClientStream::~QuicChromiumClientStream() { | 30 QuicChromiumClientStream::~QuicChromiumClientStream() { |
31 if (delegate_) | 31 if (delegate_) |
32 delegate_->OnClose(connection_error()); | 32 delegate_->OnClose(connection_error()); |
33 } | 33 } |
34 | 34 |
35 void QuicChromiumClientStream::OnStreamHeadersComplete(bool fin, | 35 void QuicChromiumClientStream::OnStreamHeadersComplete(bool fin, |
36 size_t frame_len) { | 36 size_t frame_len) { |
37 QuicSpdyStream::OnStreamHeadersComplete(fin, frame_len); | 37 QuicSpdyStream::OnStreamHeadersComplete(fin, frame_len); |
38 SpdyHeaderBlock headers; | |
39 SpdyFramer framer(HTTP2); | |
40 | |
41 size_t headers_len; | |
42 const char* header_data; | |
43 if (decompressed_headers().empty() && !decompressed_trailers().empty()) { | 38 if (decompressed_headers().empty() && !decompressed_trailers().empty()) { |
44 DCHECK(trailers_decompressed()); | 39 DCHECK(trailers_decompressed()); |
45 headers_len = decompressed_trailers().length(); | 40 // The delegate will read the trailers via a posted task. |
46 header_data = decompressed_trailers().data(); | 41 NotifyDelegateOfHeadersCompleteLater(response_trailers(), frame_len); |
47 } else { | 42 } else { |
48 DCHECK(!headers_delivered_); | 43 DCHECK(!headers_delivered_); |
49 headers_len = decompressed_headers().length(); | 44 SpdyHeaderBlock headers; |
50 header_data = decompressed_headers().data(); | 45 SpdyFramer framer(HTTP2); |
51 } | 46 size_t headers_len = decompressed_headers().length(); |
52 if (!framer.ParseHeaderBlockInBuffer(header_data, headers_len, &headers)) { | 47 const char* header_data = decompressed_headers().data(); |
53 DLOG(WARNING) << "Invalid headers"; | 48 if (!framer.ParseHeaderBlockInBuffer(header_data, headers_len, &headers)) { |
54 Reset(QUIC_BAD_APPLICATION_PAYLOAD); | 49 DLOG(WARNING) << "Invalid headers"; |
55 return; | 50 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
56 } | 51 return; |
57 | 52 } |
58 if (!headers_delivered_) { | |
59 MarkHeadersConsumed(headers_len); | 53 MarkHeadersConsumed(headers_len); |
60 session_->OnInitialHeadersComplete(id(), headers); | 54 session_->OnInitialHeadersComplete(id(), headers); |
61 } else { | 55 |
62 MarkTrailersConsumed(headers_len); | 56 // The delegate will read the headers via a posted task. |
| 57 NotifyDelegateOfHeadersCompleteLater(headers, frame_len); |
63 } | 58 } |
64 | |
65 // The delegate will read the headers via a posted task. | |
66 NotifyDelegateOfHeadersCompleteLater(headers, frame_len); | |
67 } | 59 } |
68 | 60 |
69 void QuicChromiumClientStream::OnPromiseHeadersComplete( | 61 void QuicChromiumClientStream::OnPromiseHeadersComplete( |
70 QuicStreamId promised_id, | 62 QuicStreamId promised_id, |
71 size_t frame_len) { | 63 size_t frame_len) { |
72 size_t headers_len = decompressed_headers().length(); | 64 size_t headers_len = decompressed_headers().length(); |
73 SpdyHeaderBlock headers; | 65 SpdyHeaderBlock headers; |
74 SpdyFramer framer(HTTP2); | 66 SpdyFramer framer(HTTP2); |
75 if (!framer.ParseHeaderBlockInBuffer(decompressed_headers().data(), | 67 if (!framer.ParseHeaderBlockInBuffer(decompressed_headers().data(), |
76 headers_len, &headers)) { | 68 headers_len, &headers)) { |
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
186 RunOrBuffer( | 178 RunOrBuffer( |
187 base::Bind(&QuicChromiumClientStream::NotifyDelegateOfHeadersComplete, | 179 base::Bind(&QuicChromiumClientStream::NotifyDelegateOfHeadersComplete, |
188 weak_factory_.GetWeakPtr(), headers, frame_len)); | 180 weak_factory_.GetWeakPtr(), headers, frame_len)); |
189 } | 181 } |
190 | 182 |
191 void QuicChromiumClientStream::NotifyDelegateOfHeadersComplete( | 183 void QuicChromiumClientStream::NotifyDelegateOfHeadersComplete( |
192 SpdyHeaderBlock headers, | 184 SpdyHeaderBlock headers, |
193 size_t frame_len) { | 185 size_t frame_len) { |
194 if (!delegate_) | 186 if (!delegate_) |
195 return; | 187 return; |
| 188 // Only mark trailers consumed when we are about to notify delegate. |
| 189 if (headers_delivered_) |
| 190 MarkTrailersConsumed(decompressed_trailers().length()); |
196 | 191 |
197 headers_delivered_ = true; | 192 headers_delivered_ = true; |
198 delegate_->OnHeadersAvailable(headers, frame_len); | 193 delegate_->OnHeadersAvailable(headers, frame_len); |
199 } | 194 } |
200 | 195 |
201 void QuicChromiumClientStream::NotifyDelegateOfDataAvailableLater() { | 196 void QuicChromiumClientStream::NotifyDelegateOfDataAvailableLater() { |
202 RunOrBuffer( | 197 RunOrBuffer( |
203 base::Bind(&QuicChromiumClientStream::NotifyDelegateOfDataAvailable, | 198 base::Bind(&QuicChromiumClientStream::NotifyDelegateOfDataAvailable, |
204 weak_factory_.GetWeakPtr())); | 199 weak_factory_.GetWeakPtr())); |
205 } | 200 } |
206 | 201 |
207 void QuicChromiumClientStream::NotifyDelegateOfDataAvailable() { | 202 void QuicChromiumClientStream::NotifyDelegateOfDataAvailable() { |
208 if (delegate_) | 203 if (delegate_) |
209 delegate_->OnDataAvailable(); | 204 delegate_->OnDataAvailable(); |
210 } | 205 } |
211 | 206 |
212 void QuicChromiumClientStream::RunOrBuffer(base::Closure closure) { | 207 void QuicChromiumClientStream::RunOrBuffer(base::Closure closure) { |
213 if (delegate_) { | 208 if (delegate_) { |
214 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, closure); | 209 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, closure); |
215 } else { | 210 } else { |
216 delegate_tasks_.push_back(closure); | 211 delegate_tasks_.push_back(closure); |
217 } | 212 } |
218 } | 213 } |
219 | 214 |
220 } // namespace net | 215 } // namespace net |
OLD | NEW |