K2LL33D SHELL

 Apache/2.4.7 (Ubuntu)
 Linux sman1baleendah 3.13.0-24-generic #46-Ubuntu SMP Thu Apr 10 19:11:08 UTC 2014 x86_64
 uid=33(www-data) gid=33(www-data) groups=33(www-data)
 safemode : OFF
 MySQL: ON | Perl: ON | cURL: OFF | WGet: ON
  >  / usr / lib / python2.7 / encodings /
server ip : 172.67.156.115

your ip : 172.69.17.19

H O M E


Filename/usr/lib/python2.7/encodings/zlib_codec.py
Size2.94 kb
Permissionrw-r--r--
Ownerroot : root
Create time27-Apr-2025 09:52
Last modified23-Mar-2014 07:55
Last accessed06-Jul-2025 03:26
Actionsedit | rename | delete | download (gzip)
Viewtext | code | image
""" Python 'zlib_codec' Codec - zlib compression encoding

Unlike most of the other codecs which target Unicode, this codec
will return Python string objects for both encode and decode.

Written by Marc-Andre Lemburg ([email protected]).

"""
import codecs
import zlib # this codec needs the optional zlib module !

### Codec APIs

def zlib_encode(input,errors='strict'):

""" Encodes the object input and returns a tuple (output
object, length consumed).

errors defines the error handling to apply. It defaults to
'strict' handling which is the only currently supported
error handling for this codec.

"""
assert errors == 'strict'
output = zlib.compress(input)
return (output, len(input))

def zlib_decode(input,errors='strict'):

""" Decodes the object input and returns a tuple (output
object, length consumed).

input must be an object which provides the bf_getreadbuf
buffer slot. Python strings, buffer objects and memory
mapped files are examples of objects providing this slot.

errors defines the error handling to apply. It defaults to
'strict' handling which is the only currently supported
error handling for this codec.

"""
assert errors == 'strict'
output = zlib.decompress(input)
return (output, len(input))

class Codec(codecs.Codec):

def encode(self, input, errors='strict'):
return zlib_encode(input, errors)
def decode(self, input, errors='strict'):
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):
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):
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

class StreamReader(Codec,codecs.StreamReader):
pass

### encodings module API

def getregentry():
return codecs.CodecInfo(
name='zlib',
encode=zlib_encode,
decode=zlib_decode,
incrementalencoder=IncrementalEncoder,
incrementaldecoder=IncrementalDecoder,
streamreader=StreamReader,
streamwriter=StreamWriter,
)