| OLD | NEW | 
|---|
| 1 // Copyright (c) 2016 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2016 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 #ifndef NET_QUIC_QUIC_HEADER_LIST_H_ | 5 #ifndef NET_QUIC_QUIC_HEADER_LIST_H_ | 
| 6 #define NET_QUIC_QUIC_HEADER_LIST_H_ | 6 #define NET_QUIC_QUIC_HEADER_LIST_H_ | 
| 7 | 7 | 
| 8 #include <deque> | 8 #include <deque> | 
| 9 #include <functional> | 9 #include <functional> | 
| 10 | 10 | 
| 11 #include "base/strings/string_piece.h" | 11 #include "base/strings/string_piece.h" | 
| 12 #include "net/base/net_export.h" | 12 #include "net/base/net_export.h" | 
| 13 #include "net/quic/quic_bug_tracker.h" | 13 #include "net/quic/quic_bug_tracker.h" | 
| 14 #include "net/spdy/spdy_header_block.h" | 14 #include "net/spdy/spdy_header_block.h" | 
| 15 #include "net/spdy/spdy_headers_handler_interface.h" | 15 #include "net/spdy/spdy_headers_handler_interface.h" | 
| 16 | 16 | 
| 17 namespace net { | 17 namespace net { | 
| 18 | 18 | 
| 19 // A simple class that accumulates header pairs | 19 // A simple class that accumulates header pairs | 
| 20 class NET_EXPORT_PRIVATE QuicHeaderList : public SpdyHeadersHandlerInterface { | 20 class NET_EXPORT_PRIVATE QuicHeaderList : public SpdyHeadersHandlerInterface { | 
| 21  public: | 21  public: | 
| 22   typedef std::deque<std::pair<std::string, std::string>> ListType; | 22   typedef std::deque<std::pair<std::string, std::string>> ListType; | 
|  | 23   typedef ListType::const_iterator const_iterator; | 
| 23 | 24 | 
| 24   QuicHeaderList(); | 25   QuicHeaderList(); | 
| 25   QuicHeaderList(QuicHeaderList&& other); | 26   QuicHeaderList(QuicHeaderList&& other); | 
| 26   QuicHeaderList(const QuicHeaderList& other); | 27   QuicHeaderList(const QuicHeaderList& other); | 
| 27   QuicHeaderList& operator=(QuicHeaderList&& other); | 28   QuicHeaderList& operator=(QuicHeaderList&& other); | 
| 28   QuicHeaderList& operator=(const QuicHeaderList& other); | 29   QuicHeaderList& operator=(const QuicHeaderList& other); | 
| 29   ~QuicHeaderList() override; | 30   ~QuicHeaderList() override; | 
| 30 | 31 | 
| 31   // From SpdyHeadersHandlerInteface. | 32   // From SpdyHeadersHandlerInteface. | 
| 32   void OnHeaderBlockStart() override; | 33   void OnHeaderBlockStart() override; | 
| 33   void OnHeader(base::StringPiece name, base::StringPiece value) override; | 34   void OnHeader(base::StringPiece name, base::StringPiece value) override; | 
| 34   void OnHeaderBlockEnd(size_t uncompressed_header_bytes) override; | 35   void OnHeaderBlockEnd(size_t uncompressed_header_bytes) override; | 
| 35 | 36 | 
| 36   void Clear(); | 37   void Clear(); | 
| 37 | 38 | 
| 38   ListType::const_iterator begin() const { return header_list_.begin(); } | 39   const_iterator begin() const { return header_list_.begin(); } | 
| 39   ListType::const_iterator end() const { return header_list_.end(); } | 40   const_iterator end() const { return header_list_.end(); } | 
| 40 | 41 | 
| 41   bool empty() const { return header_list_.empty(); } | 42   bool empty() const { return header_list_.empty(); } | 
| 42   size_t uncompressed_header_bytes() const { | 43   size_t uncompressed_header_bytes() const { | 
| 43     return uncompressed_header_bytes_; | 44     return uncompressed_header_bytes_; | 
| 44   } | 45   } | 
| 45 | 46 | 
|  | 47   std::string DebugString() const; | 
|  | 48 | 
| 46  private: | 49  private: | 
| 47   std::deque<std::pair<std::string, std::string>> header_list_; | 50   std::deque<std::pair<std::string, std::string>> header_list_; | 
| 48   size_t uncompressed_header_bytes_; | 51   size_t uncompressed_header_bytes_; | 
| 49 }; | 52 }; | 
| 50 | 53 | 
| 51 }  // namespace net | 54 }  // namespace net | 
| 52 | 55 | 
| 53 #endif  // NET_QUIC_QUIC_HEADER_LIST_H_ | 56 #endif  // NET_QUIC_QUIC_HEADER_LIST_H_ | 
| OLD | NEW | 
|---|