/* * Copyright 2010 The Android Open Source Project * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef SkFlate_DEFINED #define SkFlate_DEFINED #include "SkTypes.h" #include "SkStream.h" class SkData; /** \class SkFlate A class to provide access to the flate compression algorithm. */ class SkFlate { public: /** * Use the flate compression algorithm to compress the data in src, * putting the result into dst. Returns false if an error occurs. */ static bool Deflate(SkStream* src, SkWStream* dst); /** * Use the flate compression algorithm to compress the data in src, * putting the result into dst. Returns false if an error occurs. */ static bool Deflate(const void* src, size_t len, SkWStream* dst); /** * Use the flate compression algorithm to compress the data, * putting the result into dst. Returns false if an error occurs. */ static bool Deflate(const SkData*, SkWStream* dst); /** Use the flate compression algorithm to decompress the data in src, putting the result into dst. Returns false if an error occurs. */ static bool Inflate(SkStream* src, SkWStream* dst); }; /** * Wrap a stream in this class to compress the information written to * this stream using the Deflate algorithm. Uses Zlib's * Z_DEFAULT_COMPRESSION level. * * See http://en.wikipedia.org/wiki/DEFLATE */ class SkDeflateWStream : public SkWStream { public: /** Does not take ownership of the stream. */ SkDeflateWStream(SkWStream*); /** The destructor calls finalize(). */ ~SkDeflateWStream(); /** Write the end of the compressed stream. All subsequent calls to write() will fail. Subsequent calls to finalize() do nothing. */ void finalize(); // The SkWStream interface: bool write(const void*, size_t) override; size_t bytesWritten() const override; private: struct Impl; SkAutoTDelete<Impl> fImpl; }; #endif // SkFlate_DEFINED