diff options
| author | Georg Brandl <georg@python.org> | 2006-10-29 14:39:13 (GMT) |
|---|---|---|
| committer | Georg Brandl <georg@python.org> | 2006-10-29 14:39:13 (GMT) |
| commit | c68d2cc3f2950d8132ea83bcf2c9fc1359e99a4d (patch) | |
| tree | 6a6a8745273c794f08343f21bfbe18cb7452541c /Lib/encodings/zlib_codec.py | |
| parent | b8205a11882161968fe9b67871d4000c4b3efb08 (diff) | |
| download | cpython-c68d2cc3f2950d8132ea83bcf2c9fc1359e99a4d.zip cpython-c68d2cc3f2950d8132ea83bcf2c9fc1359e99a4d.tar.gz cpython-c68d2cc3f2950d8132ea83bcf2c9fc1359e99a4d.tar.bz2 | |
Bug #1586613: fix zlib and bz2 codecs' incremental en/decoders.
(backport from rev. 52529)
Diffstat (limited to 'Lib/encodings/zlib_codec.py')
| -rw-r--r-- | Lib/encodings/zlib_codec.py | 30 |
1 files changed, 26 insertions, 4 deletions
diff --git a/Lib/encodings/zlib_codec.py b/Lib/encodings/zlib_codec.py index 2694f15..3419f9f 100644 --- a/Lib/encodings/zlib_codec.py +++ b/Lib/encodings/zlib_codec.py @@ -51,14 +51,36 @@ class Codec(codecs.Codec): return zlib_decode(input, errors) class IncrementalEncoder(codecs.IncrementalEncoder): + def __init__(self, errors='strict'): + assert errors == 'strict' + self.errors = errors + self.compressobj = zlib.compressobj() + def encode(self, input, final=False): - assert self.errors == 'strict' - return zlib.compress(input) + if final: + c = self.compressobj.compress(input) + return c + self.compressobj.flush() + else: + return self.compressobj.compress(input) + + def reset(self): + self.compressobj = zlib.compressobj() class IncrementalDecoder(codecs.IncrementalDecoder): + def __init__(self, errors='strict'): + assert errors == 'strict' + self.errors = errors + self.decompressobj = zlib.decompressobj() + def decode(self, input, final=False): - assert self.errors == 'strict' - return zlib.decompress(input) + if final: + c = self.decompressobj.decompress(input) + return c + self.decompressobj.flush() + else: + return self.decompressobj.decompress(input) + + def reset(self): + self.decompressobj = zlib.decompressobj() class StreamWriter(Codec,codecs.StreamWriter): pass |
