// Copyright 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_WEBSOCKETS_WEBSOCKET_DEFLATER_H_ #define NET_WEBSOCKETS_WEBSOCKET_DEFLATER_H_ #include <deque> #include <vector> #include "base/basictypes.h" #include "base/memory/ref_counted.h" #include "base/memory/scoped_ptr.h" #include "net/base/net_export.h" extern "C" struct z_stream_s; namespace net { class IOBufferWithSize; class NET_EXPORT_PRIVATE WebSocketDeflater { public: enum ContextTakeOverMode { DO_NOT_TAKE_OVER_CONTEXT, TAKE_OVER_CONTEXT, }; explicit WebSocketDeflater(ContextTakeOverMode mode); ~WebSocketDeflater(); // Returns true if there is no error and false otherwise. // This function must be called exactly once before calling any of // following methods. // |window_bits| must be between 8 and 15 (both inclusive). bool Initialize(int window_bits); // Adds bytes to |stream_|. // Returns true if there is no error and false otherwise. bool AddBytes(const char* data, size_t size); // Flushes the current processing data. // Returns true if there is no error and false otherwise. bool Finish(); // Pushes "\x00\x00\xff\xff" to the end of the buffer. void PushSyncMark(); // Returns the current deflated output. // If the current output is larger than |size| bytes, // returns the first |size| bytes of the current output. // The returned bytes will be dropped from the current output and never be // returned thereafter. scoped_refptr<IOBufferWithSize> GetOutput(size_t size); // Returns the size of the current deflated output. size_t CurrentOutputSize() const { return buffer_.size(); } private: void ResetContext(); int Deflate(int flush); scoped_ptr<z_stream_s> stream_; ContextTakeOverMode mode_; std::deque<char> buffer_; std::vector<char> fixed_buffer_; // true if bytes were added after last Finish(). bool are_bytes_added_; DISALLOW_COPY_AND_ASSIGN(WebSocketDeflater); }; } // namespace net #endif // NET_WEBSOCKETS_WEBSOCKET_DEFLATER_H_