Linux premium71.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
LiteSpeed
Server IP : 198.187.29.8 & Your IP : 216.73.216.206
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
python34 /
lib64 /
python3.4 /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
asyncio
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
collections
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
concurrent
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
config-3.4m
[ DIR ]
drwxr-xr-x
2024-05-22 10:37
ctypes
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
curses
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
dbm
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
distutils
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
email
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
encodings
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
ensurepip
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
html
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
http
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
idlelib
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
importlib
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
json
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
lib-dynload
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
lib2to3
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
logging
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
multiprocessing
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
plat-linux
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
pydoc_data
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
site-packages
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
sqlite3
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
test
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
unittest
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
urllib
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
venv
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
wsgiref
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
xml
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
xmlrpc
[ DIR ]
drwxr-xr-x
2024-05-22 10:36
__future__.py
4.48
KB
-rw-r--r--
2024-04-17 17:10
__phello__.foo.py
64
B
-rw-r--r--
2024-04-17 17:10
_bootlocale.py
1.27
KB
-rw-r--r--
2024-04-17 17:09
_collections_abc.py
19.43
KB
-rw-r--r--
2024-04-17 17:09
_compat_pickle.py
8.12
KB
-rw-r--r--
2024-04-17 17:10
_dummy_thread.py
4.76
KB
-rw-r--r--
2024-04-17 17:10
_markupbase.py
14.26
KB
-rw-r--r--
2024-04-17 17:09
_osx_support.py
18.65
KB
-rw-r--r--
2024-04-17 17:10
_pyio.py
72.16
KB
-rw-r--r--
2024-04-17 17:09
_sitebuiltins.py
3.04
KB
-rw-r--r--
2024-04-17 17:09
_strptime.py
21.54
KB
-rw-r--r--
2024-04-17 17:10
_sysconfigdata.py
28.05
KB
-rw-r--r--
2024-04-17 17:10
_threading_local.py
7.24
KB
-rw-r--r--
2024-04-17 17:09
_weakrefset.py
5.57
KB
-rw-r--r--
2024-04-17 17:09
abc.py
8.42
KB
-rw-r--r--
2024-04-17 17:09
aifc.py
30.84
KB
-rw-r--r--
2024-04-17 17:10
antigravity.py
475
B
-rw-r--r--
2024-04-17 17:09
argparse.py
87.92
KB
-rw-r--r--
2024-04-17 17:10
ast.py
11.75
KB
-rw-r--r--
2024-04-17 17:10
asynchat.py
11.55
KB
-rw-r--r--
2024-04-17 17:10
asyncore.py
20.51
KB
-rw-r--r--
2024-04-17 17:10
base64.py
19.71
KB
-rwxr-xr-x
2024-04-17 17:09
bdb.py
22.81
KB
-rw-r--r--
2024-04-17 17:10
binhex.py
13.6
KB
-rw-r--r--
2024-04-17 17:09
bisect.py
2.53
KB
-rw-r--r--
2024-04-17 17:09
bz2.py
18.42
KB
-rw-r--r--
2024-04-17 17:10
cProfile.py
5.2
KB
-rwxr-xr-x
2024-04-17 17:09
calendar.py
22.4
KB
-rw-r--r--
2024-04-17 17:10
cgi.py
35.1
KB
-rwxr-xr-x
2024-04-17 17:10
cgitb.py
11.76
KB
-rw-r--r--
2024-04-17 17:10
chunk.py
5.3
KB
-rw-r--r--
2024-04-17 17:09
cmd.py
14.51
KB
-rw-r--r--
2024-04-17 17:09
code.py
9.8
KB
-rw-r--r--
2024-04-17 17:09
codecs.py
35.07
KB
-rw-r--r--
2024-04-17 17:09
codeop.py
5.85
KB
-rw-r--r--
2024-04-17 17:09
colorsys.py
3.97
KB
-rw-r--r--
2024-04-17 17:09
compileall.py
9.39
KB
-rw-r--r--
2024-04-17 17:09
configparser.py
48.53
KB
-rw-r--r--
2024-04-17 17:09
contextlib.py
11.37
KB
-rw-r--r--
2024-04-17 17:09
copy.py
8.79
KB
-rw-r--r--
2024-04-17 17:09
copyreg.py
6.67
KB
-rw-r--r--
2024-04-17 17:10
crypt.py
1.83
KB
-rw-r--r--
2024-04-17 17:09
csv.py
15.81
KB
-rw-r--r--
2024-04-17 17:09
datetime.py
74.03
KB
-rw-r--r--
2024-04-17 17:10
decimal.py
223.33
KB
-rw-r--r--
2024-04-17 17:10
difflib.py
79.77
KB
-rw-r--r--
2024-04-17 17:09
dis.py
16.76
KB
-rw-r--r--
2024-04-17 17:09
doctest.py
102.04
KB
-rw-r--r--
2024-04-17 17:09
dummy_threading.py
2.75
KB
-rw-r--r--
2024-04-17 17:09
enum.py
21.03
KB
-rw-r--r--
2024-04-17 17:09
filecmp.py
9.6
KB
-rw-r--r--
2024-04-17 17:09
fileinput.py
14.52
KB
-rw-r--r--
2024-04-17 17:09
fnmatch.py
3.09
KB
-rw-r--r--
2024-04-17 17:09
formatter.py
14.82
KB
-rw-r--r--
2024-04-17 17:09
fractions.py
22.66
KB
-rw-r--r--
2024-04-17 17:09
ftplib.py
37.63
KB
-rw-r--r--
2024-04-17 17:09
functools.py
27.84
KB
-rw-r--r--
2024-04-17 17:10
genericpath.py
3.79
KB
-rw-r--r--
2024-04-17 17:10
getopt.py
7.31
KB
-rw-r--r--
2024-04-17 17:10
getpass.py
5.93
KB
-rw-r--r--
2024-04-17 17:09
gettext.py
20.28
KB
-rw-r--r--
2024-04-17 17:10
glob.py
3.38
KB
-rw-r--r--
2024-04-17 17:09
gzip.py
23.74
KB
-rw-r--r--
2024-04-17 17:10
hashlib.py
9.62
KB
-rw-r--r--
2024-04-17 17:10
heapq.py
17.58
KB
-rw-r--r--
2024-04-17 17:09
hmac.py
4.94
KB
-rw-r--r--
2024-04-17 17:09
imaplib.py
49.09
KB
-rw-r--r--
2024-04-17 17:10
imghdr.py
3.45
KB
-rw-r--r--
2024-04-17 17:10
imp.py
9.75
KB
-rw-r--r--
2024-04-17 17:09
inspect.py
102.19
KB
-rw-r--r--
2024-04-17 17:10
io.py
3.32
KB
-rw-r--r--
2024-04-17 17:09
ipaddress.py
69.92
KB
-rw-r--r--
2024-04-17 17:10
keyword.py
2.17
KB
-rwxr-xr-x
2024-04-17 17:10
linecache.py
3.86
KB
-rw-r--r--
2024-04-17 17:09
locale.py
72.78
KB
-rw-r--r--
2024-04-17 17:10
lzma.py
18.92
KB
-rw-r--r--
2024-04-17 17:10
macpath.py
5.49
KB
-rw-r--r--
2024-04-17 17:09
macurl2path.py
2.67
KB
-rw-r--r--
2024-04-17 17:09
mailbox.py
76.54
KB
-rw-r--r--
2024-04-17 17:10
mailcap.py
7.26
KB
-rw-r--r--
2024-04-17 17:09
mimetypes.py
20.29
KB
-rw-r--r--
2024-04-17 17:10
modulefinder.py
22.87
KB
-rw-r--r--
2024-04-17 17:09
netrc.py
5.61
KB
-rw-r--r--
2024-04-17 17:09
nntplib.py
42.07
KB
-rw-r--r--
2024-04-17 17:09
ntpath.py
20
KB
-rw-r--r--
2024-04-17 17:09
nturl2path.py
2.39
KB
-rw-r--r--
2024-04-17 17:10
numbers.py
10
KB
-rw-r--r--
2024-04-17 17:10
opcode.py
5.31
KB
-rw-r--r--
2024-04-17 17:10
operator.py
8.98
KB
-rw-r--r--
2024-04-17 17:10
optparse.py
58.93
KB
-rw-r--r--
2024-04-17 17:10
os.py
33.09
KB
-rw-r--r--
2024-04-17 17:09
pathlib.py
41.47
KB
-rw-r--r--
2024-04-17 17:10
pdb.py
59.56
KB
-rwxr-xr-x
2024-04-17 17:09
pickle.py
54.68
KB
-rw-r--r--
2024-04-17 17:09
pickletools.py
89.61
KB
-rw-r--r--
2024-04-17 17:09
pipes.py
8.71
KB
-rw-r--r--
2024-04-17 17:10
pkgutil.py
20.72
KB
-rw-r--r--
2024-04-17 17:09
platform.py
45.67
KB
-rwxr-xr-x
2024-04-17 17:09
plistlib.py
31.05
KB
-rw-r--r--
2024-04-17 17:09
poplib.py
13.98
KB
-rw-r--r--
2024-04-17 17:09
posixpath.py
13.13
KB
-rw-r--r--
2024-04-17 17:09
pprint.py
14.57
KB
-rw-r--r--
2024-04-17 17:09
profile.py
21.52
KB
-rwxr-xr-x
2024-04-17 17:09
pstats.py
25.7
KB
-rw-r--r--
2024-04-17 17:09
pty.py
4.65
KB
-rw-r--r--
2024-04-17 17:09
py_compile.py
6.94
KB
-rw-r--r--
2024-04-17 17:10
pyclbr.py
13.2
KB
-rw-r--r--
2024-04-17 17:09
pydoc.py
100.6
KB
-rwxr-xr-x
2024-04-17 17:09
queue.py
8.63
KB
-rw-r--r--
2024-04-17 17:10
quopri.py
7.09
KB
-rwxr-xr-x
2024-04-17 17:10
random.py
25.47
KB
-rw-r--r--
2024-04-17 17:09
re.py
15.24
KB
-rw-r--r--
2024-04-17 17:09
reprlib.py
4.99
KB
-rw-r--r--
2024-04-17 17:09
rlcompleter.py
5.93
KB
-rw-r--r--
2024-04-17 17:10
runpy.py
10.56
KB
-rw-r--r--
2024-04-17 17:09
sched.py
6.21
KB
-rw-r--r--
2024-04-17 17:10
selectors.py
16.7
KB
-rw-r--r--
2024-04-17 17:09
shelve.py
8.33
KB
-rw-r--r--
2024-04-17 17:10
shlex.py
11.28
KB
-rw-r--r--
2024-04-17 17:10
shutil.py
38.97
KB
-rw-r--r--
2024-04-17 17:10
site.py
21.05
KB
-rw-r--r--
2024-04-17 17:10
smtpd.py
29.29
KB
-rwxr-xr-x
2024-04-17 17:09
smtplib.py
38.06
KB
-rwxr-xr-x
2024-04-17 17:09
sndhdr.py
6.11
KB
-rw-r--r--
2024-04-17 17:10
socket.py
18.62
KB
-rw-r--r--
2024-04-17 17:10
socketserver.py
23.8
KB
-rw-r--r--
2024-04-17 17:10
sre_compile.py
19.44
KB
-rw-r--r--
2024-04-17 17:09
sre_constants.py
7.1
KB
-rw-r--r--
2024-04-17 17:09
sre_parse.py
30.69
KB
-rw-r--r--
2024-04-17 17:09
ssl.py
33.93
KB
-rw-r--r--
2024-04-17 17:10
stat.py
4.3
KB
-rw-r--r--
2024-04-17 17:10
statistics.py
19.1
KB
-rw-r--r--
2024-04-17 17:09
string.py
11.18
KB
-rw-r--r--
2024-04-17 17:10
stringprep.py
12.61
KB
-rw-r--r--
2024-04-17 17:09
struct.py
257
B
-rw-r--r--
2024-04-17 17:09
subprocess.py
63.04
KB
-rw-r--r--
2024-04-17 17:09
sunau.py
17.67
KB
-rw-r--r--
2024-04-17 17:09
symbol.py
2
KB
-rwxr-xr-x
2024-04-17 17:09
symtable.py
7.23
KB
-rw-r--r--
2024-04-17 17:10
sysconfig.py
24.05
KB
-rw-r--r--
2024-04-17 17:10
tabnanny.py
11.14
KB
-rwxr-xr-x
2024-04-17 17:10
tarfile.py
89.41
KB
-rwxr-xr-x
2024-04-17 17:09
telnetlib.py
22.53
KB
-rw-r--r--
2024-04-17 17:09
tempfile.py
22
KB
-rw-r--r--
2024-04-17 17:09
textwrap.py
18.83
KB
-rw-r--r--
2024-04-17 17:09
this.py
1003
B
-rw-r--r--
2024-04-17 17:09
threading.py
47.66
KB
-rw-r--r--
2024-04-17 17:10
timeit.py
11.69
KB
-rwxr-xr-x
2024-04-17 17:09
token.py
2.96
KB
-rw-r--r--
2024-04-17 17:09
tokenize.py
25
KB
-rw-r--r--
2024-04-17 17:10
trace.py
30.75
KB
-rwxr-xr-x
2024-04-17 17:09
traceback.py
10.91
KB
-rw-r--r--
2024-04-17 17:10
tracemalloc.py
15.28
KB
-rw-r--r--
2024-04-17 17:10
tty.py
879
B
-rw-r--r--
2024-04-17 17:09
types.py
5.28
KB
-rw-r--r--
2024-04-17 17:09
uu.py
6.61
KB
-rwxr-xr-x
2024-04-17 17:09
uuid.py
23.17
KB
-rw-r--r--
2024-04-17 17:09
warnings.py
13.97
KB
-rw-r--r--
2024-04-17 17:09
wave.py
17.27
KB
-rw-r--r--
2024-04-17 17:09
weakref.py
18.93
KB
-rw-r--r--
2024-04-17 17:10
webbrowser.py
20.93
KB
-rwxr-xr-x
2024-04-17 17:10
xdrlib.py
5.77
KB
-rw-r--r--
2024-04-17 17:10
zipfile.py
66.94
KB
-rw-r--r--
2024-04-17 17:10
Save
Rename
"""Macintosh binhex compression/decompression. easy interface: binhex(inputfilename, outputfilename) hexbin(inputfilename, outputfilename) """ # # Jack Jansen, CWI, August 1995. # # The module is supposed to be as compatible as possible. Especially the # easy interface should work "as expected" on any platform. # XXXX Note: currently, textfiles appear in mac-form on all platforms. # We seem to lack a simple character-translate in python. # (we should probably use ISO-Latin-1 on all but the mac platform). # XXXX The simple routines are too simple: they expect to hold the complete # files in-core. Should be fixed. # XXXX It would be nice to handle AppleDouble format on unix # (for servers serving macs). # XXXX I don't understand what happens when you get 0x90 times the same byte on # input. The resulting code (xx 90 90) would appear to be interpreted as an # escaped *value* of 0x90. All coders I've seen appear to ignore this nicety... # import io import os import struct import binascii __all__ = ["binhex","hexbin","Error"] class Error(Exception): pass # States (what have we written) _DID_HEADER = 0 _DID_DATA = 1 # Various constants REASONABLY_LARGE = 32768 # Minimal amount we pass the rle-coder LINELEN = 64 RUNCHAR = b"\x90" # # This code is no longer byte-order dependent class FInfo: def __init__(self): self.Type = '????' self.Creator = '????' self.Flags = 0 def getfileinfo(name): finfo = FInfo() with io.open(name, 'rb') as fp: # Quick check for textfile data = fp.read(512) if 0 not in data: finfo.Type = 'TEXT' fp.seek(0, 2) dsize = fp.tell() dir, file = os.path.split(name) file = file.replace(':', '-', 1) return file, finfo, dsize, 0 class openrsrc: def __init__(self, *args): pass def read(self, *args): return b'' def write(self, *args): pass def close(self): pass class _Hqxcoderengine: """Write data to the coder in 3-byte chunks""" def __init__(self, ofp): self.ofp = ofp self.data = b'' self.hqxdata = b'' self.linelen = LINELEN - 1 def write(self, data): self.data = self.data + data datalen = len(self.data) todo = (datalen // 3) * 3 data = self.data[:todo] self.data = self.data[todo:] if not data: return self.hqxdata = self.hqxdata + binascii.b2a_hqx(data) self._flush(0) def _flush(self, force): first = 0 while first <= len(self.hqxdata) - self.linelen: last = first + self.linelen self.ofp.write(self.hqxdata[first:last] + b'\n') self.linelen = LINELEN first = last self.hqxdata = self.hqxdata[first:] if force: self.ofp.write(self.hqxdata + b':\n') def close(self): if self.data: self.hqxdata = self.hqxdata + binascii.b2a_hqx(self.data) self._flush(1) self.ofp.close() del self.ofp class _Rlecoderengine: """Write data to the RLE-coder in suitably large chunks""" def __init__(self, ofp): self.ofp = ofp self.data = b'' def write(self, data): self.data = self.data + data if len(self.data) < REASONABLY_LARGE: return rledata = binascii.rlecode_hqx(self.data) self.ofp.write(rledata) self.data = b'' def close(self): if self.data: rledata = binascii.rlecode_hqx(self.data) self.ofp.write(rledata) self.ofp.close() del self.ofp class BinHex: def __init__(self, name_finfo_dlen_rlen, ofp): name, finfo, dlen, rlen = name_finfo_dlen_rlen close_on_error = False if isinstance(ofp, str): ofname = ofp ofp = io.open(ofname, 'wb') close_on_error = True try: ofp.write(b'(This file must be converted with BinHex 4.0)\r\r:') hqxer = _Hqxcoderengine(ofp) self.ofp = _Rlecoderengine(hqxer) self.crc = 0 if finfo is None: finfo = FInfo() self.dlen = dlen self.rlen = rlen self._writeinfo(name, finfo) self.state = _DID_HEADER except: if close_on_error: ofp.close() raise def _writeinfo(self, name, finfo): nl = len(name) if nl > 63: raise Error('Filename too long') d = bytes([nl]) + name.encode("latin-1") + b'\0' tp, cr = finfo.Type, finfo.Creator if isinstance(tp, str): tp = tp.encode("latin-1") if isinstance(cr, str): cr = cr.encode("latin-1") d2 = tp + cr # Force all structs to be packed with big-endian d3 = struct.pack('>h', finfo.Flags) d4 = struct.pack('>ii', self.dlen, self.rlen) info = d + d2 + d3 + d4 self._write(info) self._writecrc() def _write(self, data): self.crc = binascii.crc_hqx(data, self.crc) self.ofp.write(data) def _writecrc(self): # XXXX Should this be here?? # self.crc = binascii.crc_hqx('\0\0', self.crc) if self.crc < 0: fmt = '>h' else: fmt = '>H' self.ofp.write(struct.pack(fmt, self.crc)) self.crc = 0 def write(self, data): if self.state != _DID_HEADER: raise Error('Writing data at the wrong time') self.dlen = self.dlen - len(data) self._write(data) def close_data(self): if self.dlen != 0: raise Error('Incorrect data size, diff=%r' % (self.rlen,)) self._writecrc() self.state = _DID_DATA def write_rsrc(self, data): if self.state < _DID_DATA: self.close_data() if self.state != _DID_DATA: raise Error('Writing resource data at the wrong time') self.rlen = self.rlen - len(data) self._write(data) def close(self): if self.state is None: return try: if self.state < _DID_DATA: self.close_data() if self.state != _DID_DATA: raise Error('Close at the wrong time') if self.rlen != 0: raise Error("Incorrect resource-datasize, diff=%r" % (self.rlen,)) self._writecrc() finally: self.state = None ofp = self.ofp del self.ofp ofp.close() def binhex(inp, out): """binhex(infilename, outfilename): create binhex-encoded copy of a file""" finfo = getfileinfo(inp) ofp = BinHex(finfo, out) ifp = io.open(inp, 'rb') # XXXX Do textfile translation on non-mac systems while True: d = ifp.read(128000) if not d: break ofp.write(d) ofp.close_data() ifp.close() ifp = openrsrc(inp, 'rb') while True: d = ifp.read(128000) if not d: break ofp.write_rsrc(d) ofp.close() ifp.close() class _Hqxdecoderengine: """Read data via the decoder in 4-byte chunks""" def __init__(self, ifp): self.ifp = ifp self.eof = 0 def read(self, totalwtd): """Read at least wtd bytes (or until EOF)""" decdata = b'' wtd = totalwtd # # The loop here is convoluted, since we don't really now how # much to decode: there may be newlines in the incoming data. while wtd > 0: if self.eof: return decdata wtd = ((wtd + 2) // 3) * 4 data = self.ifp.read(wtd) # # Next problem: there may not be a complete number of # bytes in what we pass to a2b. Solve by yet another # loop. # while True: try: decdatacur, self.eof = binascii.a2b_hqx(data) break except binascii.Incomplete: pass newdata = self.ifp.read(1) if not newdata: raise Error('Premature EOF on binhex file') data = data + newdata decdata = decdata + decdatacur wtd = totalwtd - len(decdata) if not decdata and not self.eof: raise Error('Premature EOF on binhex file') return decdata def close(self): self.ifp.close() class _Rledecoderengine: """Read data via the RLE-coder""" def __init__(self, ifp): self.ifp = ifp self.pre_buffer = b'' self.post_buffer = b'' self.eof = 0 def read(self, wtd): if wtd > len(self.post_buffer): self._fill(wtd - len(self.post_buffer)) rv = self.post_buffer[:wtd] self.post_buffer = self.post_buffer[wtd:] return rv def _fill(self, wtd): self.pre_buffer = self.pre_buffer + self.ifp.read(wtd + 4) if self.ifp.eof: self.post_buffer = self.post_buffer + \ binascii.rledecode_hqx(self.pre_buffer) self.pre_buffer = b'' return # # Obfuscated code ahead. We have to take care that we don't # end up with an orphaned RUNCHAR later on. So, we keep a couple # of bytes in the buffer, depending on what the end of # the buffer looks like: # '\220\0\220' - Keep 3 bytes: repeated \220 (escaped as \220\0) # '?\220' - Keep 2 bytes: repeated something-else # '\220\0' - Escaped \220: Keep 2 bytes. # '?\220?' - Complete repeat sequence: decode all # otherwise: keep 1 byte. # mark = len(self.pre_buffer) if self.pre_buffer[-3:] == RUNCHAR + b'\0' + RUNCHAR: mark = mark - 3 elif self.pre_buffer[-1:] == RUNCHAR: mark = mark - 2 elif self.pre_buffer[-2:] == RUNCHAR + b'\0': mark = mark - 2 elif self.pre_buffer[-2:-1] == RUNCHAR: pass # Decode all else: mark = mark - 1 self.post_buffer = self.post_buffer + \ binascii.rledecode_hqx(self.pre_buffer[:mark]) self.pre_buffer = self.pre_buffer[mark:] def close(self): self.ifp.close() class HexBin: def __init__(self, ifp): if isinstance(ifp, str): ifp = io.open(ifp, 'rb') # # Find initial colon. # while True: ch = ifp.read(1) if not ch: raise Error("No binhex data found") # Cater for \r\n terminated lines (which show up as \n\r, hence # all lines start with \r) if ch == b'\r': continue if ch == b':': break hqxifp = _Hqxdecoderengine(ifp) self.ifp = _Rledecoderengine(hqxifp) self.crc = 0 self._readheader() def _read(self, len): data = self.ifp.read(len) self.crc = binascii.crc_hqx(data, self.crc) return data def _checkcrc(self): filecrc = struct.unpack('>h', self.ifp.read(2))[0] & 0xffff #self.crc = binascii.crc_hqx('\0\0', self.crc) # XXXX Is this needed?? self.crc = self.crc & 0xffff if filecrc != self.crc: raise Error('CRC error, computed %x, read %x' % (self.crc, filecrc)) self.crc = 0 def _readheader(self): len = self._read(1) fname = self._read(ord(len)) rest = self._read(1 + 4 + 4 + 2 + 4 + 4) self._checkcrc() type = rest[1:5] creator = rest[5:9] flags = struct.unpack('>h', rest[9:11])[0] self.dlen = struct.unpack('>l', rest[11:15])[0] self.rlen = struct.unpack('>l', rest[15:19])[0] self.FName = fname self.FInfo = FInfo() self.FInfo.Creator = creator self.FInfo.Type = type self.FInfo.Flags = flags self.state = _DID_HEADER def read(self, *n): if self.state != _DID_HEADER: raise Error('Read data at wrong time') if n: n = n[0] n = min(n, self.dlen) else: n = self.dlen rv = b'' while len(rv) < n: rv = rv + self._read(n-len(rv)) self.dlen = self.dlen - n return rv def close_data(self): if self.state != _DID_HEADER: raise Error('close_data at wrong time') if self.dlen: dummy = self._read(self.dlen) self._checkcrc() self.state = _DID_DATA def read_rsrc(self, *n): if self.state == _DID_HEADER: self.close_data() if self.state != _DID_DATA: raise Error('Read resource data at wrong time') if n: n = n[0] n = min(n, self.rlen) else: n = self.rlen self.rlen = self.rlen - n return self._read(n) def close(self): if self.state is None: return try: if self.rlen: dummy = self.read_rsrc(self.rlen) self._checkcrc() finally: self.state = None self.ifp.close() def hexbin(inp, out): """hexbin(infilename, outfilename) - Decode binhexed file""" ifp = HexBin(inp) finfo = ifp.FInfo if not out: out = ifp.FName ofp = io.open(out, 'wb') # XXXX Do translation on non-mac systems while True: d = ifp.read(128000) if not d: break ofp.write(d) ofp.close() ifp.close_data() d = ifp.read_rsrc(128000) if d: ofp = openrsrc(out, 'wb') ofp.write(d) while True: d = ifp.read_rsrc(128000) if not d: break ofp.write(d) ofp.close() ifp.close()