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/chromium/quic_chromium_client_session.h" | 5 #include "net/quic/chromium/quic_chromium_client_session.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/callback_helpers.h" | 9 #include "base/callback_helpers.h" |
10 #include "base/location.h" | 10 #include "base/location.h" |
(...skipping 283 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
294 if (!session_) | 294 if (!session_) |
295 return ERR_CONNECTION_CLOSED; | 295 return ERR_CONNECTION_CLOSED; |
296 | 296 |
297 // base::MakeUnique does not work because the StreamRequest constructor | 297 // base::MakeUnique does not work because the StreamRequest constructor |
298 // is private. | 298 // is private. |
299 stream_request_ = std::unique_ptr<StreamRequest>( | 299 stream_request_ = std::unique_ptr<StreamRequest>( |
300 new StreamRequest(this, requires_confirmation)); | 300 new StreamRequest(this, requires_confirmation)); |
301 return stream_request_->StartRequest(callback); | 301 return stream_request_->StartRequest(callback); |
302 } | 302 } |
303 | 303 |
304 QuicChromiumClientStream* QuicChromiumClientSession::Handle::ReleaseStream() { | 304 QuicChromiumClientStream* QuicChromiumClientSession::Handle::ReleaseStream( |
| 305 QuicChromiumClientStream::Delegate* delegate) { |
305 DCHECK(stream_request_); | 306 DCHECK(stream_request_); |
306 | 307 |
307 auto* stream = stream_request_->ReleaseStream(); | 308 auto* stream = stream_request_->ReleaseStream(delegate); |
308 stream_request_.reset(); | 309 stream_request_.reset(); |
309 return stream; | 310 return stream; |
310 } | 311 } |
311 | 312 |
312 int QuicChromiumClientSession::Handle::WaitForHandshakeConfirmation( | 313 int QuicChromiumClientSession::Handle::WaitForHandshakeConfirmation( |
313 const CompletionCallback& callback) { | 314 const CompletionCallback& callback) { |
314 if (!session_) | 315 if (!session_) |
315 return ERR_CONNECTION_CLOSED; | 316 return ERR_CONNECTION_CLOSED; |
316 | 317 |
317 return session_->WaitForHandshakeConfirmation(callback); | 318 return session_->WaitForHandshakeConfirmation(callback); |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
369 | 370 |
370 next_state_ = STATE_WAIT_FOR_CONFIRMATION; | 371 next_state_ = STATE_WAIT_FOR_CONFIRMATION; |
371 int rv = DoLoop(OK); | 372 int rv = DoLoop(OK); |
372 if (rv == ERR_IO_PENDING) | 373 if (rv == ERR_IO_PENDING) |
373 callback_ = callback; | 374 callback_ = callback; |
374 | 375 |
375 return rv; | 376 return rv; |
376 } | 377 } |
377 | 378 |
378 QuicChromiumClientStream* | 379 QuicChromiumClientStream* |
379 QuicChromiumClientSession::StreamRequest::ReleaseStream() { | 380 QuicChromiumClientSession::StreamRequest::ReleaseStream( |
| 381 QuicChromiumClientStream::Delegate* delegate) { |
380 DCHECK(stream_); | 382 DCHECK(stream_); |
381 QuicChromiumClientStream* stream = stream_; | 383 QuicChromiumClientStream* stream = stream_; |
382 stream_ = nullptr; | 384 stream_ = nullptr; |
| 385 stream->SetDelegate(delegate); |
383 return stream; | 386 return stream; |
384 } | 387 } |
385 | 388 |
386 void QuicChromiumClientSession::StreamRequest::OnRequestCompleteSuccess( | 389 void QuicChromiumClientSession::StreamRequest::OnRequestCompleteSuccess( |
387 QuicChromiumClientStream* stream) { | 390 QuicChromiumClientStream* stream) { |
388 DCHECK_EQ(STATE_REQUEST_STREAM_COMPLETE, next_state_); | 391 DCHECK_EQ(STATE_REQUEST_STREAM_COMPLETE, next_state_); |
389 | 392 |
390 stream_ = stream; | 393 stream_ = stream; |
391 // This method is called even when the request completes synchronously. | 394 // This method is called even when the request completes synchronously. |
392 if (callback_) | 395 if (callback_) |
(...skipping 1361 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1754 } | 1757 } |
1755 | 1758 |
1756 size_t QuicChromiumClientSession::EstimateMemoryUsage() const { | 1759 size_t QuicChromiumClientSession::EstimateMemoryUsage() const { |
1757 // TODO(xunjieli): Estimate |crypto_stream_|, QuicSpdySession's | 1760 // TODO(xunjieli): Estimate |crypto_stream_|, QuicSpdySession's |
1758 // QuicHeaderList, QuicSession's QuiCWriteBlockedList, open streams and | 1761 // QuicHeaderList, QuicSession's QuiCWriteBlockedList, open streams and |
1759 // unacked packet map. | 1762 // unacked packet map. |
1760 return base::trace_event::EstimateMemoryUsage(packet_readers_); | 1763 return base::trace_event::EstimateMemoryUsage(packet_readers_); |
1761 } | 1764 } |
1762 | 1765 |
1763 } // namespace net | 1766 } // namespace net |
OLD | NEW |