OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2017 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef NET_QUIC_CORE_QUIC_STREAM_FRAME_DATA_PRODUCER_H_ |
| 6 #define NET_QUIC_CORE_QUIC_STREAM_FRAME_DATA_PRODUCER_H_ |
| 7 |
| 8 #include "net/quic/core/quic_iovector.h" |
| 9 #include "net/quic/core/quic_types.h" |
| 10 |
| 11 namespace net { |
| 12 |
| 13 class QuicDataWriter; |
| 14 |
| 15 // Pure virtual class to save and retrieve stream data. |
| 16 class QUIC_EXPORT_PRIVATE QuicStreamFrameDataProducer { |
| 17 public: |
| 18 virtual ~QuicStreamFrameDataProducer() {} |
| 19 |
| 20 // Save |data_length| data starts at |iov_offset| in |iov|. |
| 21 virtual void SaveStreamData(QuicStreamId id, |
| 22 QuicIOVector iov, |
| 23 size_t iov_offset, |
| 24 QuicStreamOffset offset, |
| 25 QuicByteCount data_length) = 0; |
| 26 |
| 27 // Let |writer| write |data_length| data with |offset| of stream |id|. Returns |
| 28 // false when the writing fails either because stream is closed or |
| 29 // corresponding data is failed to be retrieved. This method allows writing a |
| 30 // single stream frame from data that spans multiple buffers. |
| 31 virtual bool WriteStreamData(QuicStreamId id, |
| 32 QuicStreamOffset offset, |
| 33 QuicByteCount data_length, |
| 34 QuicDataWriter* writer) = 0; |
| 35 }; |
| 36 |
| 37 } // namespace net |
| 38 |
| 39 #endif // NET_QUIC_CORE_QUIC_STREAM_FRAME_DATA_PRODUCER_H_ |
OLD | NEW |