1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2010 The Android Open Source Project 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker 9*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkFlate_DEFINED 10*c8dee2aaSAndroid Build Coastguard Worker #define SkFlate_DEFINED 11*c8dee2aaSAndroid Build Coastguard Worker 12*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkStream.h" 13*c8dee2aaSAndroid Build Coastguard Worker #include <cstddef> 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker #include <memory> 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker /** 18*c8dee2aaSAndroid Build Coastguard Worker * Wrap a stream in this class to compress the information written to 19*c8dee2aaSAndroid Build Coastguard Worker * this stream using the Deflate algorithm. 20*c8dee2aaSAndroid Build Coastguard Worker * 21*c8dee2aaSAndroid Build Coastguard Worker * See http://en.wikipedia.org/wiki/DEFLATE 22*c8dee2aaSAndroid Build Coastguard Worker */ 23*c8dee2aaSAndroid Build Coastguard Worker class SkDeflateWStream final : public SkWStream { 24*c8dee2aaSAndroid Build Coastguard Worker public: 25*c8dee2aaSAndroid Build Coastguard Worker /** Does not take ownership of the stream. 26*c8dee2aaSAndroid Build Coastguard Worker 27*c8dee2aaSAndroid Build Coastguard Worker @param compressionLevel 1 is best speed; 9 is best compression. 28*c8dee2aaSAndroid Build Coastguard Worker The default, -1, is to use zlib's Z_DEFAULT_COMPRESSION level. 29*c8dee2aaSAndroid Build Coastguard Worker 0 would be no compression, but due to broken zlibs, users should handle that themselves. 30*c8dee2aaSAndroid Build Coastguard Worker 31*c8dee2aaSAndroid Build Coastguard Worker @param gzip iff true, output a gzip file. "The gzip format is 32*c8dee2aaSAndroid Build Coastguard Worker a wrapper, documented in RFC 1952, around a deflate stream." 33*c8dee2aaSAndroid Build Coastguard Worker gzip adds a header with a magic number to the beginning of the 34*c8dee2aaSAndroid Build Coastguard Worker stream, allowing a client to identify a gzip file. 35*c8dee2aaSAndroid Build Coastguard Worker */ 36*c8dee2aaSAndroid Build Coastguard Worker SkDeflateWStream(SkWStream*, 37*c8dee2aaSAndroid Build Coastguard Worker int compressionLevel, 38*c8dee2aaSAndroid Build Coastguard Worker bool gzip = false); 39*c8dee2aaSAndroid Build Coastguard Worker 40*c8dee2aaSAndroid Build Coastguard Worker /** The destructor calls finalize(). */ 41*c8dee2aaSAndroid Build Coastguard Worker ~SkDeflateWStream() override; 42*c8dee2aaSAndroid Build Coastguard Worker 43*c8dee2aaSAndroid Build Coastguard Worker /** Write the end of the compressed stream. All subsequent calls to 44*c8dee2aaSAndroid Build Coastguard Worker write() will fail. Subsequent calls to finalize() do nothing. */ 45*c8dee2aaSAndroid Build Coastguard Worker void finalize(); 46*c8dee2aaSAndroid Build Coastguard Worker 47*c8dee2aaSAndroid Build Coastguard Worker // The SkWStream interface: 48*c8dee2aaSAndroid Build Coastguard Worker bool write(const void*, size_t) override; 49*c8dee2aaSAndroid Build Coastguard Worker size_t bytesWritten() const override; 50*c8dee2aaSAndroid Build Coastguard Worker 51*c8dee2aaSAndroid Build Coastguard Worker private: 52*c8dee2aaSAndroid Build Coastguard Worker struct Impl; 53*c8dee2aaSAndroid Build Coastguard Worker std::unique_ptr<Impl> fImpl; 54*c8dee2aaSAndroid Build Coastguard Worker }; 55*c8dee2aaSAndroid Build Coastguard Worker 56*c8dee2aaSAndroid Build Coastguard Worker #endif // SkFlate_DEFINED 57