| 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 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 51 } | 51 } |
| 52 if (!framer.ParseHeaderBlockInBuffer(header_data, headers_len, &headers)) { | 52 if (!framer.ParseHeaderBlockInBuffer(header_data, headers_len, &headers)) { |
| 53 DLOG(WARNING) << "Invalid headers"; | 53 DLOG(WARNING) << "Invalid headers"; |
| 54 Reset(QUIC_BAD_APPLICATION_PAYLOAD); | 54 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
| 55 return; | 55 return; |
| 56 } | 56 } |
| 57 | 57 |
| 58 if (!headers_delivered_) { | 58 if (!headers_delivered_) { |
| 59 MarkHeadersConsumed(headers_len); | 59 MarkHeadersConsumed(headers_len); |
| 60 session_->OnInitialHeadersComplete(id(), headers); | 60 session_->OnInitialHeadersComplete(id(), headers); |
| 61 // The delegate will read the headers via a posted task. |
| 62 NotifyDelegateOfHeadersCompleteLater(headers, frame_len); |
| 61 } else { | 63 } else { |
| 62 MarkTrailersConsumed(headers_len); | 64 MarkTrailersConsumed(headers_len); |
| 65 NotifyDelegateOfHeadersCompleteLater(headers, frame_len); |
| 66 OnStreamFrame( |
| 67 QuicStreamFrame(id(), fin, stream_bytes_read(), StringPiece())); |
| 63 } | 68 } |
| 64 | |
| 65 // The delegate will read the headers via a posted task. | |
| 66 NotifyDelegateOfHeadersCompleteLater(headers, frame_len); | |
| 67 } | 69 } |
| 68 | 70 |
| 69 void QuicChromiumClientStream::OnPromiseHeadersComplete( | 71 void QuicChromiumClientStream::OnPromiseHeadersComplete( |
| 70 QuicStreamId promised_id, | 72 QuicStreamId promised_id, |
| 71 size_t frame_len) { | 73 size_t frame_len) { |
| 72 size_t headers_len = decompressed_headers().length(); | 74 size_t headers_len = decompressed_headers().length(); |
| 73 SpdyHeaderBlock headers; | 75 SpdyHeaderBlock headers; |
| 74 SpdyFramer framer(HTTP2); | 76 SpdyFramer framer(HTTP2); |
| 75 if (!framer.ParseHeaderBlockInBuffer(decompressed_headers().data(), | 77 if (!framer.ParseHeaderBlockInBuffer(decompressed_headers().data(), |
| 76 headers_len, &headers)) { | 78 headers_len, &headers)) { |
| (...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 211 | 213 |
| 212 void QuicChromiumClientStream::RunOrBuffer(base::Closure closure) { | 214 void QuicChromiumClientStream::RunOrBuffer(base::Closure closure) { |
| 213 if (delegate_) { | 215 if (delegate_) { |
| 214 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, closure); | 216 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, closure); |
| 215 } else { | 217 } else { |
| 216 delegate_tasks_.push_back(closure); | 218 delegate_tasks_.push_back(closure); |
| 217 } | 219 } |
| 218 } | 220 } |
| 219 | 221 |
| 220 } // namespace net | 222 } // namespace net |
| OLD | NEW |