diff options
author | Jeff Muizelaar <jeff@infidigm.net> | 2005-04-27 20:56:18 +0000 |
---|---|---|
committer | Jeff Muizelaar <jeff@infidigm.net> | 2005-04-27 20:56:18 +0000 |
commit | c2db3e1b297a9dc0accd0d8a1366970d45705c8f (patch) | |
tree | 2dff633663bc8172010b53f6551a2cfb3dc9c95e /poppler/FlateStream.cc | |
parent | bc0afe524c2b87af191d83fc9e9bcdc8a6ce4042 (diff) |
2005-04-27 Jeff Muizelaar <jeff@infidigm.net>
* configure.ac:
* poppler/FlateStream.cc:
* poppler/FlateStream.h:
* poppler/Makefile.am:
* poppler/Stream.cc:
* poppler/Stream.h: Add a reimplementation of FlateStream using
zlib.
Diffstat (limited to 'poppler/FlateStream.cc')
-rw-r--r-- | poppler/FlateStream.cc | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/poppler/FlateStream.cc b/poppler/FlateStream.cc new file mode 100644 index 00000000..7557cecc --- /dev/null +++ b/poppler/FlateStream.cc @@ -0,0 +1,107 @@ +//======================================================================== +// +// FlateStream.cc +// +// Copyright (C) 2005, Jeff Muizelaar +// +//======================================================================== +#include "FlateStream.h" +FlateStream::FlateStream(Stream *strA, int predictor, int columns, int colors, int bits) : + FilterStream(strA) +{ + if (predictor != 1) { + pred = new StreamPredictor(this, predictor, columns, colors, bits); + } else { + pred = NULL; + } + out_pos = 0; + memset(&d_stream, 0, sizeof(d_stream)); +} + +FlateStream::~FlateStream() { + inflateEnd(&d_stream); + delete str; +} + +void FlateStream::reset() { + //FIXME: what are the semantics of reset? + //i.e. how much intialization has to happen in the constructor? + str->reset(); + memset(&d_stream, 0, sizeof(d_stream)); + inflateInit(&d_stream); + d_stream.avail_in = 0; + status = Z_OK; + out_pos = 0; + out_buf_len = 0; +} + +int FlateStream::getRawChar() { + if (fill_buffer()) + return EOF; + + return out_buf[out_pos++]; +} + +int FlateStream::getChar() { + if (pred) + return pred->getChar(); + else + return getRawChar(); +} + +int FlateStream::lookChar() { + if (pred) + return pred->lookChar(); + + if (fill_buffer()) + return EOF; + + return out_buf[out_pos]; +} + +int FlateStream::fill_buffer() { + if (out_pos >= out_buf_len) { + if (status == Z_STREAM_END) { + return -1; + } + d_stream.avail_out = sizeof(out_buf); + d_stream.next_out = out_buf; + out_pos = 0; + /* buffer is empty so we need to fill it */ + if (d_stream.avail_in == 0) { + int c; + /* read from the source stream */ + while (d_stream.avail_in < sizeof(in_buf) && (c = str->getChar()) != EOF) { + in_buf[d_stream.avail_in++] = c; + } + d_stream.next_in = in_buf; + } + while (d_stream.avail_out && d_stream.avail_in && (status == Z_OK || status == Z_BUF_ERROR)) { + status = inflate(&d_stream, Z_SYNC_FLUSH); + } + out_buf_len = sizeof(out_buf) - d_stream.avail_out; + if (status != Z_OK && status != Z_STREAM_END) + return -1; + if (!out_buf_len) + return -1; + } + + return 0; +} + +GooString *FlateStream::getPSFilter(int psLevel, char *indent) { + GooString *s; + + if (psLevel < 3 || pred) { + return NULL; + } + if (!(s = str->getPSFilter(psLevel, indent))) { + return NULL; + } + s->append(indent)->append("<< >> /FlateDecode filter\n"); + return s; +} + +GBool FlateStream::isBinary(GBool last) { + return str->isBinary(gTrue); +} |