X7ROOT File Manager
Current Path:
/opt/alt/python27/lib64/python2.7
opt
/
alt
/
python27
/
lib64
/
python2.7
/
ðŸ“
..
📄
BaseHTTPServer.py
(22.21 KB)
📄
BaseHTTPServer.pyc
(21.47 KB)
📄
BaseHTTPServer.pyo
(21.47 KB)
📄
Bastion.py
(5.61 KB)
📄
Bastion.pyc
(6.69 KB)
📄
Bastion.pyo
(6.69 KB)
📄
CGIHTTPServer.py
(12.78 KB)
📄
CGIHTTPServer.pyc
(10.92 KB)
📄
CGIHTTPServer.pyo
(10.92 KB)
📄
ConfigParser.py
(27.1 KB)
📄
ConfigParser.pyc
(25.37 KB)
📄
ConfigParser.pyo
(25.37 KB)
📄
Cookie.py
(25.92 KB)
📄
Cookie.pyc
(22.61 KB)
📄
Cookie.pyo
(22.61 KB)
📄
DocXMLRPCServer.py
(10.52 KB)
📄
DocXMLRPCServer.pyc
(10.2 KB)
📄
DocXMLRPCServer.pyo
(10.09 KB)
📄
HTMLParser.py
(16.77 KB)
📄
HTMLParser.pyc
(13.81 KB)
📄
HTMLParser.pyo
(13.51 KB)
📄
MimeWriter.py
(6.33 KB)
📄
MimeWriter.pyc
(7.31 KB)
📄
MimeWriter.pyo
(7.31 KB)
📄
Queue.py
(8.38 KB)
📄
Queue.pyc
(9.56 KB)
📄
Queue.pyo
(9.56 KB)
📄
SimpleHTTPServer.py
(7.81 KB)
📄
SimpleHTTPServer.pyc
(7.96 KB)
📄
SimpleHTTPServer.pyo
(7.96 KB)
📄
SimpleXMLRPCServer.py
(25.21 KB)
📄
SimpleXMLRPCServer.pyc
(22.78 KB)
📄
SimpleXMLRPCServer.pyo
(22.78 KB)
📄
SocketServer.py
(23.39 KB)
📄
SocketServer.pyc
(24.25 KB)
📄
SocketServer.pyo
(24.25 KB)
📄
StringIO.py
(10.41 KB)
📄
StringIO.pyc
(11.45 KB)
📄
StringIO.pyo
(11.45 KB)
📄
UserDict.py
(6.89 KB)
📄
UserDict.pyc
(10.05 KB)
📄
UserDict.pyo
(10.05 KB)
📄
UserList.py
(3.56 KB)
📄
UserList.pyc
(6.85 KB)
📄
UserList.pyo
(6.85 KB)
📄
UserString.py
(9.47 KB)
📄
UserString.pyc
(15.38 KB)
📄
UserString.pyo
(15.38 KB)
📄
_LWPCookieJar.py
(6.4 KB)
📄
_LWPCookieJar.pyc
(5.38 KB)
📄
_LWPCookieJar.pyo
(5.38 KB)
📄
_MozillaCookieJar.py
(5.66 KB)
📄
_MozillaCookieJar.pyc
(4.41 KB)
📄
_MozillaCookieJar.pyo
(4.37 KB)
📄
__future__.py
(4.28 KB)
📄
__future__.pyc
(4.2 KB)
📄
__future__.pyo
(4.2 KB)
📄
__phello__.foo.py
(64 B)
📄
__phello__.foo.pyc
(138 B)
📄
__phello__.foo.pyo
(138 B)
📄
_abcoll.py
(18.18 KB)
📄
_abcoll.pyc
(26.4 KB)
📄
_abcoll.pyo
(26.4 KB)
📄
_osx_support.py
(18.65 KB)
📄
_osx_support.pyc
(11.72 KB)
📄
_osx_support.pyo
(11.72 KB)
📄
_pyio.py
(68 KB)
📄
_pyio.pyc
(65.41 KB)
📄
_pyio.pyo
(65.41 KB)
📄
_strptime.py
(20.24 KB)
📄
_strptime.pyc
(15.07 KB)
📄
_strptime.pyo
(15.07 KB)
📄
_sysconfigdata.py
(20.67 KB)
📄
_sysconfigdata.pyc
(23.71 KB)
📄
_sysconfigdata.pyo
(23.71 KB)
📄
_threading_local.py
(7.09 KB)
📄
_threading_local.pyc
(6.34 KB)
📄
_threading_local.pyo
(6.34 KB)
📄
_weakrefset.py
(5.77 KB)
📄
_weakrefset.pyc
(10.06 KB)
📄
_weakrefset.pyo
(10.06 KB)
📄
abc.py
(6.98 KB)
📄
abc.pyc
(6.14 KB)
📄
abc.pyo
(6.08 KB)
📄
aifc.py
(33.77 KB)
📄
aifc.pyc
(30.67 KB)
📄
aifc.pyo
(30.67 KB)
📄
antigravity.py
(60 B)
📄
antigravity.pyc
(216 B)
📄
antigravity.pyo
(216 B)
📄
anydbm.py
(2.6 KB)
📄
anydbm.pyc
(2.77 KB)
📄
anydbm.pyo
(2.77 KB)
📄
argparse.py
(87.14 KB)
📄
argparse.pyc
(64.83 KB)
📄
argparse.pyo
(64.67 KB)
📄
ast.py
(11.53 KB)
📄
ast.pyc
(12.94 KB)
📄
ast.pyo
(12.94 KB)
📄
asynchat.py
(11.31 KB)
📄
asynchat.pyc
(8.98 KB)
📄
asynchat.pyo
(8.98 KB)
📄
asyncore.py
(20.45 KB)
📄
asyncore.pyc
(19.2 KB)
📄
asyncore.pyo
(19.2 KB)
📄
atexit.py
(1.67 KB)
📄
atexit.pyc
(2.23 KB)
📄
atexit.pyo
(2.23 KB)
📄
audiodev.py
(7.42 KB)
📄
audiodev.pyc
(8.61 KB)
📄
audiodev.pyo
(8.61 KB)
📄
base64.py
(11.54 KB)
📄
base64.pyc
(11.26 KB)
📄
base64.pyo
(11.26 KB)
📄
bdb.py
(21.21 KB)
📄
bdb.pyc
(19.43 KB)
📄
bdb.pyo
(19.43 KB)
📄
binhex.py
(14.35 KB)
📄
binhex.pyc
(15.75 KB)
📄
binhex.pyo
(15.75 KB)
📄
bisect.py
(2.53 KB)
📄
bisect.pyc
(3.06 KB)
📄
bisect.pyo
(3.06 KB)
ðŸ“
bsddb
📄
cProfile.py
(6.43 KB)
📄
cProfile.pyc
(6.42 KB)
📄
cProfile.pyo
(6.42 KB)
📄
calendar.py
(22.84 KB)
📄
calendar.pyc
(28.26 KB)
📄
calendar.pyo
(28.26 KB)
📄
cgi.py
(34.97 KB)
📄
cgi.pyc
(33.24 KB)
📄
cgi.pyo
(33.24 KB)
📄
cgitb.py
(11.89 KB)
📄
cgitb.pyc
(12.08 KB)
📄
cgitb.pyo
(12.08 KB)
📄
chunk.py
(5.29 KB)
📄
chunk.pyc
(5.61 KB)
📄
chunk.pyo
(5.61 KB)
📄
cmd.py
(14.67 KB)
📄
cmd.pyc
(13.98 KB)
📄
cmd.pyo
(13.98 KB)
📄
code.py
(9.95 KB)
📄
code.pyc
(10.29 KB)
📄
code.pyo
(10.29 KB)
📄
codecs.py
(35.3 KB)
📄
codecs.pyc
(37.15 KB)
📄
codecs.pyo
(37.15 KB)
📄
codeop.py
(5.86 KB)
📄
codeop.pyc
(6.57 KB)
📄
codeop.pyo
(6.57 KB)
📄
collections.py
(27.15 KB)
📄
collections.pyc
(26.21 KB)
📄
collections.pyo
(26.16 KB)
📄
colorsys.py
(3.6 KB)
📄
colorsys.pyc
(4 KB)
📄
colorsys.pyo
(4 KB)
📄
commands.py
(2.49 KB)
📄
commands.pyc
(2.49 KB)
📄
commands.pyo
(2.49 KB)
📄
compileall.py
(7.58 KB)
📄
compileall.pyc
(6.93 KB)
📄
compileall.pyo
(6.93 KB)
ðŸ“
compiler
ðŸ“
config
📄
contextlib.py
(4.32 KB)
📄
contextlib.pyc
(4.5 KB)
📄
contextlib.pyo
(4.5 KB)
📄
cookielib.py
(63.95 KB)
📄
cookielib.pyc
(54.67 KB)
📄
cookielib.pyo
(54.49 KB)
📄
copy.py
(11.26 KB)
📄
copy.pyc
(12.21 KB)
📄
copy.pyo
(12.13 KB)
📄
copy_reg.py
(6.81 KB)
📄
copy_reg.pyc
(5.19 KB)
📄
copy_reg.pyo
(5.14 KB)
📄
crypt.py
(2.24 KB)
📄
crypt.pyc
(2.95 KB)
📄
crypt.pyo
(2.95 KB)
📄
csv.py
(16.32 KB)
📄
csv.pyc
(13.56 KB)
📄
csv.pyo
(13.56 KB)
ðŸ“
ctypes
ðŸ“
curses
📄
dbhash.py
(498 B)
📄
dbhash.pyc
(744 B)
📄
dbhash.pyo
(744 B)
📄
decimal.py
(216.73 KB)
📄
decimal.pyc
(171.36 KB)
📄
decimal.pyo
(171.36 KB)
📄
difflib.py
(80.4 KB)
📄
difflib.pyc
(61.13 KB)
📄
difflib.pyo
(61.08 KB)
📄
dircache.py
(1.1 KB)
📄
dircache.pyc
(1.59 KB)
📄
dircache.pyo
(1.59 KB)
📄
dis.py
(6.35 KB)
📄
dis.pyc
(6.18 KB)
📄
dis.pyo
(6.18 KB)
ðŸ“
distutils
📄
doctest.py
(102.63 KB)
📄
doctest.pyc
(83.21 KB)
📄
doctest.pyo
(82.93 KB)
📄
dumbdbm.py
(8.93 KB)
📄
dumbdbm.pyc
(6.83 KB)
📄
dumbdbm.pyo
(6.83 KB)
📄
dummy_thread.py
(4.31 KB)
📄
dummy_thread.pyc
(5.46 KB)
📄
dummy_thread.pyo
(5.46 KB)
📄
dummy_threading.py
(2.74 KB)
📄
dummy_threading.pyc
(1.27 KB)
📄
dummy_threading.pyo
(1.27 KB)
ðŸ“
email
ðŸ“
encodings
ðŸ“
ensurepip
📄
filecmp.py
(9.36 KB)
📄
filecmp.pyc
(9.65 KB)
📄
filecmp.pyo
(9.65 KB)
📄
fileinput.py
(13.42 KB)
📄
fileinput.pyc
(14.54 KB)
📄
fileinput.pyo
(14.54 KB)
📄
fnmatch.py
(3.24 KB)
📄
fnmatch.pyc
(3.61 KB)
📄
fnmatch.pyo
(3.61 KB)
📄
formatter.py
(14.56 KB)
📄
formatter.pyc
(19.71 KB)
📄
formatter.pyo
(19.71 KB)
📄
fpformat.py
(4.62 KB)
📄
fpformat.pyc
(4.69 KB)
📄
fpformat.pyo
(4.69 KB)
📄
fractions.py
(21.87 KB)
📄
fractions.pyc
(19.74 KB)
📄
fractions.pyo
(19.74 KB)
📄
ftplib.py
(37.3 KB)
📄
ftplib.pyc
(34.82 KB)
📄
ftplib.pyo
(34.82 KB)
📄
functools.py
(4.69 KB)
📄
functools.pyc
(6.85 KB)
📄
functools.pyo
(6.85 KB)
📄
genericpath.py
(3.13 KB)
📄
genericpath.pyc
(3.57 KB)
📄
genericpath.pyo
(3.57 KB)
📄
getopt.py
(7.15 KB)
📄
getopt.pyc
(6.63 KB)
📄
getopt.pyo
(6.58 KB)
📄
getpass.py
(5.43 KB)
📄
getpass.pyc
(4.72 KB)
📄
getpass.pyo
(4.72 KB)
📄
gettext.py
(22.13 KB)
📄
gettext.pyc
(18.17 KB)
📄
gettext.pyo
(18.17 KB)
📄
glob.py
(3.04 KB)
📄
glob.pyc
(2.98 KB)
📄
glob.pyo
(2.98 KB)
📄
gzip.py
(18.58 KB)
📄
gzip.pyc
(15.26 KB)
📄
gzip.pyo
(15.26 KB)
📄
hashlib.py
(7.66 KB)
📄
hashlib.pyc
(6.86 KB)
📄
hashlib.pyo
(6.86 KB)
📄
heapq.py
(17.87 KB)
📄
heapq.pyc
(14.45 KB)
📄
heapq.pyo
(14.45 KB)
📄
hmac.py
(4.48 KB)
📄
hmac.pyc
(4.56 KB)
📄
hmac.pyo
(4.56 KB)
ðŸ“
hotshot
📄
htmlentitydefs.py
(17.63 KB)
📄
htmlentitydefs.pyc
(6.23 KB)
📄
htmlentitydefs.pyo
(6.23 KB)
📄
htmllib.py
(12.57 KB)
📄
htmllib.pyc
(20.99 KB)
📄
htmllib.pyo
(20.99 KB)
📄
httplib.py
(51.07 KB)
📄
httplib.pyc
(37.88 KB)
📄
httplib.pyo
(37.7 KB)
ðŸ“
idlelib
📄
ihooks.py
(18.54 KB)
📄
ihooks.pyc
(21.75 KB)
📄
ihooks.pyo
(21.75 KB)
📄
imaplib.py
(47.23 KB)
📄
imaplib.pyc
(45.19 KB)
📄
imaplib.pyo
(42.49 KB)
📄
imghdr.py
(3.46 KB)
📄
imghdr.pyc
(4.93 KB)
📄
imghdr.pyo
(4.93 KB)
ðŸ“
importlib
📄
imputil.py
(25.16 KB)
📄
imputil.pyc
(15.74 KB)
📄
imputil.pyo
(15.57 KB)
📄
inspect.py
(42 KB)
📄
inspect.pyc
(40.16 KB)
📄
inspect.pyo
(40.16 KB)
📄
io.py
(3.24 KB)
📄
io.pyc
(3.57 KB)
📄
io.pyo
(3.57 KB)
ðŸ“
json
📄
keyword.py
(1.96 KB)
📄
keyword.pyc
(2.08 KB)
📄
keyword.pyo
(2.08 KB)
ðŸ“
lib-dynload
ðŸ“
lib2to3
📄
linecache.py
(3.93 KB)
📄
linecache.pyc
(3.27 KB)
📄
linecache.pyo
(3.27 KB)
📄
locale.py
(100.42 KB)
📄
locale.pyc
(55.69 KB)
📄
locale.pyo
(55.69 KB)
ðŸ“
logging
📄
macpath.py
(6.14 KB)
📄
macpath.pyc
(7.74 KB)
📄
macpath.pyo
(7.74 KB)
📄
macurl2path.py
(2.67 KB)
📄
macurl2path.pyc
(2.24 KB)
📄
macurl2path.pyo
(2.24 KB)
📄
mailbox.py
(79.34 KB)
📄
mailbox.pyc
(77.7 KB)
📄
mailbox.pyo
(77.65 KB)
📄
mailcap.py
(7.25 KB)
📄
mailcap.pyc
(7.08 KB)
📄
mailcap.pyo
(7.08 KB)
📄
markupbase.py
(14.3 KB)
📄
markupbase.pyc
(9.27 KB)
📄
markupbase.pyo
(9.07 KB)
📄
md5.py
(358 B)
📄
md5.pyc
(391 B)
📄
md5.pyo
(391 B)
📄
mhlib.py
(32.65 KB)
📄
mhlib.pyc
(33.98 KB)
📄
mhlib.pyo
(33.98 KB)
📄
mimetools.py
(7 KB)
📄
mimetools.pyc
(8.26 KB)
📄
mimetools.pyo
(8.26 KB)
📄
mimetypes.py
(20.54 KB)
📄
mimetypes.pyc
(18.3 KB)
📄
mimetypes.pyo
(18.3 KB)
📄
mimify.py
(14.68 KB)
📄
mimify.pyc
(11.91 KB)
📄
mimify.pyo
(11.91 KB)
📄
modulefinder.py
(23.89 KB)
📄
modulefinder.pyc
(19.12 KB)
📄
modulefinder.pyo
(19.04 KB)
📄
multifile.py
(4.71 KB)
📄
multifile.pyc
(5.48 KB)
📄
multifile.pyo
(5.44 KB)
ðŸ“
multiprocessing
📄
mutex.py
(1.83 KB)
📄
mutex.pyc
(2.55 KB)
📄
mutex.pyo
(2.55 KB)
📄
netrc.py
(5.75 KB)
📄
netrc.pyc
(4.72 KB)
📄
netrc.pyo
(4.72 KB)
📄
new.py
(610 B)
📄
new.pyc
(875 B)
📄
new.pyo
(875 B)
📄
nntplib.py
(20.97 KB)
📄
nntplib.pyc
(21.11 KB)
📄
nntplib.pyo
(21.11 KB)
📄
ntpath.py
(18.97 KB)
📄
ntpath.pyc
(13.1 KB)
📄
ntpath.pyo
(13.1 KB)
📄
nturl2path.py
(2.36 KB)
📄
nturl2path.pyc
(1.81 KB)
📄
nturl2path.pyo
(1.81 KB)
📄
numbers.py
(10.08 KB)
📄
numbers.pyc
(14.47 KB)
📄
numbers.pyo
(14.47 KB)
📄
opcode.py
(5.35 KB)
📄
opcode.pyc
(6.06 KB)
📄
opcode.pyo
(6.06 KB)
📄
optparse.py
(59.77 KB)
📄
optparse.pyc
(54.41 KB)
📄
optparse.pyo
(54.33 KB)
📄
os.py
(25.3 KB)
📄
os.pyc
(25.76 KB)
📄
os.pyo
(25.76 KB)
📄
os2emxpath.py
(4.53 KB)
📄
os2emxpath.pyc
(4.53 KB)
📄
os2emxpath.pyo
(4.53 KB)
📄
pdb.doc
(7.73 KB)
📄
pdb.py
(45.03 KB)
📄
pdb.pyc
(44.09 KB)
📄
pdb.pyo
(44.09 KB)
📄
pickle.py
(44.42 KB)
📄
pickle.pyc
(38.98 KB)
📄
pickle.pyo
(38.79 KB)
📄
pickletools.py
(72.78 KB)
📄
pickletools.pyc
(56.1 KB)
📄
pickletools.pyo
(55.26 KB)
📄
pipes.py
(9.36 KB)
📄
pipes.pyc
(9.29 KB)
📄
pipes.pyo
(9.29 KB)
📄
pkgutil.py
(19.77 KB)
📄
pkgutil.pyc
(18.93 KB)
📄
pkgutil.pyo
(18.93 KB)
ðŸ“
plat-linux2
📄
platform.py
(51.56 KB)
📄
platform.pyc
(37.7 KB)
📄
platform.pyo
(37.7 KB)
📄
plistlib.py
(14.83 KB)
📄
plistlib.pyc
(19.54 KB)
📄
plistlib.pyo
(19.46 KB)
📄
popen2.py
(8.22 KB)
📄
popen2.pyc
(9.02 KB)
📄
popen2.pyo
(8.98 KB)
📄
poplib.py
(12.52 KB)
📄
poplib.pyc
(13.45 KB)
📄
poplib.pyo
(13.45 KB)
📄
posixfile.py
(7.82 KB)
📄
posixfile.pyc
(7.63 KB)
📄
posixfile.pyo
(7.63 KB)
📄
posixpath.py
(13.96 KB)
📄
posixpath.pyc
(11.49 KB)
📄
posixpath.pyo
(11.49 KB)
📄
pprint.py
(11.5 KB)
📄
pprint.pyc
(10.2 KB)
📄
pprint.pyo
(10.02 KB)
📄
profile.py
(22.26 KB)
📄
profile.pyc
(16.57 KB)
📄
profile.pyo
(16.32 KB)
📄
pstats.py
(26.09 KB)
📄
pstats.pyc
(25.19 KB)
📄
pstats.pyo
(25.19 KB)
📄
pty.py
(4.94 KB)
📄
pty.pyc
(4.98 KB)
📄
pty.pyo
(4.98 KB)
📄
py_compile.py
(5.8 KB)
📄
py_compile.pyc
(6.37 KB)
📄
py_compile.pyo
(6.37 KB)
📄
pyclbr.py
(13.07 KB)
📄
pyclbr.pyc
(9.59 KB)
📄
pyclbr.pyo
(9.59 KB)
📄
pydoc.py
(93.43 KB)
📄
pydoc.pyc
(92.69 KB)
📄
pydoc.pyo
(92.63 KB)
ðŸ“
pydoc_data
📄
quopri.py
(6.81 KB)
📄
quopri.pyc
(6.56 KB)
📄
quopri.pyo
(6.56 KB)
📄
random.py
(31.7 KB)
📄
random.pyc
(25.65 KB)
📄
random.pyo
(25.65 KB)
📄
re.py
(13.11 KB)
📄
re.pyc
(13.37 KB)
📄
re.pyo
(13.37 KB)
📄
repr.py
(4.2 KB)
📄
repr.pyc
(5.47 KB)
📄
repr.pyo
(5.47 KB)
📄
rexec.py
(19.68 KB)
📄
rexec.pyc
(24 KB)
📄
rexec.pyo
(24 KB)
📄
rfc822.py
(32.76 KB)
📄
rfc822.pyc
(31.83 KB)
📄
rfc822.pyo
(31.83 KB)
📄
rlcompleter.py
(5.85 KB)
📄
rlcompleter.pyc
(6.04 KB)
📄
rlcompleter.pyo
(6.04 KB)
📄
robotparser.py
(7.51 KB)
📄
robotparser.pyc
(8.12 KB)
📄
robotparser.pyo
(8.12 KB)
📄
runpy.py
(10.82 KB)
📄
runpy.pyc
(8.85 KB)
📄
runpy.pyo
(8.85 KB)
📄
sched.py
(4.97 KB)
📄
sched.pyc
(4.99 KB)
📄
sched.pyo
(4.99 KB)
📄
sets.py
(18.6 KB)
📄
sets.pyc
(17.21 KB)
📄
sets.pyo
(17.21 KB)
📄
sgmllib.py
(17.46 KB)
📄
sgmllib.pyc
(15.67 KB)
📄
sgmllib.pyo
(15.67 KB)
📄
sha.py
(393 B)
📄
sha.pyc
(434 B)
📄
sha.pyo
(434 B)
📄
shelve.py
(7.99 KB)
📄
shelve.pyc
(10.36 KB)
📄
shelve.pyo
(10.36 KB)
📄
shlex.py
(10.9 KB)
📄
shlex.pyc
(7.55 KB)
📄
shlex.pyo
(7.55 KB)
📄
shutil.py
(19.41 KB)
📄
shutil.pyc
(19.19 KB)
📄
shutil.pyo
(19.19 KB)
ðŸ“
site-packages
📄
site.py
(19.18 KB)
📄
site.pyc
(19.35 KB)
📄
site.pyo
(19.35 KB)
📄
smtpd.py
(18.12 KB)
📄
smtpd.pyc
(15.9 KB)
📄
smtpd.pyo
(15.9 KB)
📄
smtplib.py
(31.39 KB)
📄
smtplib.pyc
(30.29 KB)
📄
smtplib.pyo
(30.29 KB)
📄
sndhdr.py
(5.83 KB)
📄
sndhdr.pyc
(7.4 KB)
📄
sndhdr.pyo
(7.4 KB)
📄
socket.py
(20.13 KB)
📄
socket.pyc
(16.15 KB)
📄
socket.pyo
(16.07 KB)
ðŸ“
sqlite3
📄
sre.py
(384 B)
📄
sre.pyc
(532 B)
📄
sre.pyo
(532 B)
📄
sre_compile.py
(19.36 KB)
📄
sre_compile.pyc
(12.46 KB)
📄
sre_compile.pyo
(12.3 KB)
📄
sre_constants.py
(7.03 KB)
📄
sre_constants.pyc
(6.11 KB)
📄
sre_constants.pyo
(6.11 KB)
📄
sre_parse.py
(29.98 KB)
📄
sre_parse.pyc
(21.12 KB)
📄
sre_parse.pyo
(21.12 KB)
📄
ssl.py
(36.58 KB)
📄
ssl.pyc
(32.24 KB)
📄
ssl.pyo
(32.24 KB)
📄
stat.py
(1.8 KB)
📄
stat.pyc
(2.81 KB)
📄
stat.pyo
(2.81 KB)
📄
statvfs.py
(898 B)
📄
statvfs.pyc
(633 B)
📄
statvfs.pyo
(633 B)
📄
string.py
(21.04 KB)
📄
string.pyc
(20.63 KB)
📄
string.pyo
(20.63 KB)
📄
stringold.py
(12.16 KB)
📄
stringold.pyc
(12.6 KB)
📄
stringold.pyo
(12.6 KB)
📄
stringprep.py
(13.21 KB)
📄
stringprep.pyc
(14.4 KB)
📄
stringprep.pyo
(14.33 KB)
📄
struct.py
(82 B)
📄
struct.pyc
(252 B)
📄
struct.pyo
(252 B)
📄
subprocess.py
(49.34 KB)
📄
subprocess.pyc
(32.32 KB)
📄
subprocess.pyo
(32.32 KB)
📄
sunau.py
(16.82 KB)
📄
sunau.pyc
(18.57 KB)
📄
sunau.pyo
(18.57 KB)
📄
sunaudio.py
(1.37 KB)
📄
sunaudio.pyc
(2 KB)
📄
sunaudio.pyo
(2 KB)
📄
symbol.py
(2.02 KB)
📄
symbol.pyc
(2.98 KB)
📄
symbol.pyo
(2.98 KB)
📄
symtable.py
(7.26 KB)
📄
symtable.pyc
(12.14 KB)
📄
symtable.pyo
(12.02 KB)
📄
sysconfig.py
(22.32 KB)
📄
sysconfig.pyc
(17.73 KB)
📄
sysconfig.pyo
(17.73 KB)
📄
tabnanny.py
(11.08 KB)
📄
tabnanny.pyc
(8.31 KB)
📄
tabnanny.pyo
(8.31 KB)
📄
tarfile.py
(88.45 KB)
📄
tarfile.pyc
(76.54 KB)
📄
tarfile.pyo
(76.54 KB)
📄
telnetlib.py
(26.4 KB)
📄
telnetlib.pyc
(23.03 KB)
📄
telnetlib.pyo
(23.03 KB)
📄
tempfile.py
(19.09 KB)
📄
tempfile.pyc
(20.55 KB)
📄
tempfile.pyo
(20.55 KB)
ðŸ“
test
📄
textwrap.py
(16.88 KB)
📄
textwrap.pyc
(11.99 KB)
📄
textwrap.pyo
(11.9 KB)
📄
this.py
(1002 B)
📄
this.pyc
(1.2 KB)
📄
this.pyo
(1.2 KB)
📄
threading.py
(46.17 KB)
📄
threading.pyc
(42.97 KB)
📄
threading.pyo
(40.84 KB)
📄
timeit.py
(12.5 KB)
📄
timeit.pyc
(12.06 KB)
📄
timeit.pyo
(12.06 KB)
📄
toaiff.py
(3.07 KB)
📄
toaiff.pyc
(3.08 KB)
📄
toaiff.pyo
(3.08 KB)
📄
token.py
(2.85 KB)
📄
token.pyc
(3.79 KB)
📄
token.pyo
(3.79 KB)
📄
tokenize.py
(17.07 KB)
📄
tokenize.pyc
(14.37 KB)
📄
tokenize.pyo
(14.31 KB)
📄
trace.py
(29.2 KB)
📄
trace.pyc
(22.69 KB)
📄
trace.pyo
(22.63 KB)
📄
traceback.py
(11.02 KB)
📄
traceback.pyc
(11.66 KB)
📄
traceback.pyo
(11.66 KB)
📄
tty.py
(879 B)
📄
tty.pyc
(1.32 KB)
📄
tty.pyo
(1.32 KB)
📄
types.py
(2.04 KB)
📄
types.pyc
(2.75 KB)
📄
types.pyo
(2.75 KB)
ðŸ“
unittest
📄
urllib.py
(58.82 KB)
📄
urllib.pyc
(51.35 KB)
📄
urllib.pyo
(51.25 KB)
📄
urllib2.py
(51.31 KB)
📄
urllib2.pyc
(47.8 KB)
📄
urllib2.pyo
(47.71 KB)
📄
urlparse.py
(16.29 KB)
📄
urlparse.pyc
(15.51 KB)
📄
urlparse.pyo
(15.51 KB)
📄
user.py
(1.59 KB)
📄
user.pyc
(1.7 KB)
📄
user.pyo
(1.7 KB)
📄
uu.py
(6.55 KB)
📄
uu.pyc
(4.35 KB)
📄
uu.pyo
(4.35 KB)
📄
uuid.py
(22.63 KB)
📄
uuid.pyc
(23.22 KB)
📄
uuid.pyo
(23.11 KB)
📄
warnings.py
(14.48 KB)
📄
warnings.pyc
(13.49 KB)
📄
warnings.pyo
(12.71 KB)
📄
wave.py
(18.15 KB)
📄
wave.pyc
(20.19 KB)
📄
wave.pyo
(20.05 KB)
📄
weakref.py
(14.48 KB)
📄
weakref.pyc
(16.73 KB)
📄
weakref.pyo
(16.73 KB)
📄
webbrowser.py
(22.2 KB)
📄
webbrowser.pyc
(19.86 KB)
📄
webbrowser.pyo
(19.81 KB)
📄
whichdb.py
(3.31 KB)
📄
whichdb.pyc
(2.21 KB)
📄
whichdb.pyo
(2.21 KB)
ðŸ“
wsgiref
📄
wsgiref.egg-info
(187 B)
📄
xdrlib.py
(5.93 KB)
📄
xdrlib.pyc
(10.2 KB)
📄
xdrlib.pyo
(10.2 KB)
ðŸ“
xml
📄
xmllib.py
(34.05 KB)
📄
xmllib.pyc
(26.9 KB)
📄
xmllib.pyo
(26.9 KB)
📄
xmlrpclib.py
(50.91 KB)
📄
xmlrpclib.pyc
(44.81 KB)
📄
xmlrpclib.pyo
(44.63 KB)
📄
zipfile.py
(58.08 KB)
📄
zipfile.pyc
(41.92 KB)
📄
zipfile.pyo
(41.92 KB)
Editing: asyncore.py
# -*- Mode: Python -*- # Id: asyncore.py,v 2.51 2000/09/07 22:29:26 rushing Exp # Author: Sam Rushing <rushing@nightmare.com> # ====================================================================== # Copyright 1996 by Sam Rushing # # All Rights Reserved # # Permission to use, copy, modify, and distribute this software and # its documentation for any purpose and without fee is hereby # granted, provided that the above copyright notice appear in all # copies and that both that copyright notice and this permission # notice appear in supporting documentation, and that the name of Sam # Rushing not be used in advertising or publicity pertaining to # distribution of the software without specific, written prior # permission. # # SAM RUSHING DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, # INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN # NO EVENT SHALL SAM RUSHING BE LIABLE FOR ANY SPECIAL, INDIRECT OR # CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS # OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, # NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN # CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. # ====================================================================== """Basic infrastructure for asynchronous socket service clients and servers. There are only two ways to have a program on a single processor do "more than one thing at a time". Multi-threaded programming is the simplest and most popular way to do it, but there is another very different technique, that lets you have nearly all the advantages of multi-threading, without actually using multiple threads. it's really only practical if your program is largely I/O bound. If your program is CPU bound, then pre-emptive scheduled threads are probably what you really need. Network servers are rarely CPU-bound, however. If your operating system supports the select() system call in its I/O library (and nearly all do), then you can use it to juggle multiple communication channels at once; doing other work while your I/O is taking place in the "background." Although this strategy can seem strange and complex, especially at first, it is in many ways easier to understand and control than multi-threaded programming. The module documented here solves many of the difficult problems for you, making the task of building sophisticated high-performance network servers and clients a snap. """ import select import socket import sys import time import warnings import os from errno import EALREADY, EINPROGRESS, EWOULDBLOCK, ECONNRESET, EINVAL, \ ENOTCONN, ESHUTDOWN, EINTR, EISCONN, EBADF, ECONNABORTED, EPIPE, EAGAIN, \ errorcode _DISCONNECTED = frozenset((ECONNRESET, ENOTCONN, ESHUTDOWN, ECONNABORTED, EPIPE, EBADF)) try: socket_map except NameError: socket_map = {} def _strerror(err): try: return os.strerror(err) except (ValueError, OverflowError, NameError): if err in errorcode: return errorcode[err] return "Unknown error %s" %err class ExitNow(Exception): pass _reraised_exceptions = (ExitNow, KeyboardInterrupt, SystemExit) def read(obj): try: obj.handle_read_event() except _reraised_exceptions: raise except: obj.handle_error() def write(obj): try: obj.handle_write_event() except _reraised_exceptions: raise except: obj.handle_error() def _exception(obj): try: obj.handle_expt_event() except _reraised_exceptions: raise except: obj.handle_error() def readwrite(obj, flags): try: if flags & select.POLLIN: obj.handle_read_event() if flags & select.POLLOUT: obj.handle_write_event() if flags & select.POLLPRI: obj.handle_expt_event() if flags & (select.POLLHUP | select.POLLERR | select.POLLNVAL): obj.handle_close() except socket.error, e: if e.args[0] not in _DISCONNECTED: obj.handle_error() else: obj.handle_close() except _reraised_exceptions: raise except: obj.handle_error() def poll(timeout=0.0, map=None): if map is None: map = socket_map if map: r = []; w = []; e = [] for fd, obj in map.items(): is_r = obj.readable() is_w = obj.writable() if is_r: r.append(fd) # accepting sockets should not be writable if is_w and not obj.accepting: w.append(fd) if is_r or is_w: e.append(fd) if [] == r == w == e: time.sleep(timeout) return try: r, w, e = select.select(r, w, e, timeout) except select.error, err: if err.args[0] != EINTR: raise else: return for fd in r: obj = map.get(fd) if obj is None: continue read(obj) for fd in w: obj = map.get(fd) if obj is None: continue write(obj) for fd in e: obj = map.get(fd) if obj is None: continue _exception(obj) def poll2(timeout=0.0, map=None): # Use the poll() support added to the select module in Python 2.0 if map is None: map = socket_map if timeout is not None: # timeout is in milliseconds timeout = int(timeout*1000) pollster = select.poll() if map: for fd, obj in map.items(): flags = 0 if obj.readable(): flags |= select.POLLIN | select.POLLPRI # accepting sockets should not be writable if obj.writable() and not obj.accepting: flags |= select.POLLOUT if flags: # Only check for exceptions if object was either readable # or writable. flags |= select.POLLERR | select.POLLHUP | select.POLLNVAL pollster.register(fd, flags) try: r = pollster.poll(timeout) except select.error, err: if err.args[0] != EINTR: raise r = [] for fd, flags in r: obj = map.get(fd) if obj is None: continue readwrite(obj, flags) poll3 = poll2 # Alias for backward compatibility def loop(timeout=30.0, use_poll=False, map=None, count=None): if map is None: map = socket_map if use_poll and hasattr(select, 'poll'): poll_fun = poll2 else: poll_fun = poll if count is None: while map: poll_fun(timeout, map) else: while map and count > 0: poll_fun(timeout, map) count = count - 1 class dispatcher: debug = False connected = False accepting = False connecting = False closing = False addr = None ignore_log_types = frozenset(['warning']) def __init__(self, sock=None, map=None): if map is None: self._map = socket_map else: self._map = map self._fileno = None if sock: # Set to nonblocking just to make sure for cases where we # get a socket from a blocking source. sock.setblocking(0) self.set_socket(sock, map) self.connected = True # The constructor no longer requires that the socket # passed be connected. try: self.addr = sock.getpeername() except socket.error, err: if err.args[0] in (ENOTCONN, EINVAL): # To handle the case where we got an unconnected # socket. self.connected = False else: # The socket is broken in some unknown way, alert # the user and remove it from the map (to prevent # polling of broken sockets). self.del_channel(map) raise else: self.socket = None def __repr__(self): status = [self.__class__.__module__+"."+self.__class__.__name__] if self.accepting and self.addr: status.append('listening') elif self.connected: status.append('connected') if self.addr is not None: try: status.append('%s:%d' % self.addr) except TypeError: status.append(repr(self.addr)) return '<%s at %#x>' % (' '.join(status), id(self)) __str__ = __repr__ def add_channel(self, map=None): #self.log_info('adding channel %s' % self) if map is None: map = self._map map[self._fileno] = self def del_channel(self, map=None): fd = self._fileno if map is None: map = self._map if fd in map: #self.log_info('closing channel %d:%s' % (fd, self)) del map[fd] self._fileno = None def create_socket(self, family, type): self.family_and_type = family, type sock = socket.socket(family, type) sock.setblocking(0) self.set_socket(sock) def set_socket(self, sock, map=None): self.socket = sock ## self.__dict__['socket'] = sock self._fileno = sock.fileno() self.add_channel(map) def set_reuse_addr(self): # try to re-use a server port if possible try: self.socket.setsockopt( socket.SOL_SOCKET, socket.SO_REUSEADDR, self.socket.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR) | 1 ) except socket.error: pass # ================================================== # predicates for select() # these are used as filters for the lists of sockets # to pass to select(). # ================================================== def readable(self): return True def writable(self): return True # ================================================== # socket object methods. # ================================================== def listen(self, num): self.accepting = True if os.name == 'nt' and num > 5: num = 5 return self.socket.listen(num) def bind(self, addr): self.addr = addr return self.socket.bind(addr) def connect(self, address): self.connected = False self.connecting = True err = self.socket.connect_ex(address) if err in (EINPROGRESS, EALREADY, EWOULDBLOCK) \ or err == EINVAL and os.name in ('nt', 'ce'): self.addr = address return if err in (0, EISCONN): self.addr = address self.handle_connect_event() else: raise socket.error(err, errorcode[err]) def accept(self): # XXX can return either an address pair or None try: conn, addr = self.socket.accept() except TypeError: return None except socket.error as why: if why.args[0] in (EWOULDBLOCK, ECONNABORTED, EAGAIN): return None else: raise else: return conn, addr def send(self, data): try: result = self.socket.send(data) return result except socket.error, why: if why.args[0] == EWOULDBLOCK: return 0 elif why.args[0] in _DISCONNECTED: self.handle_close() return 0 else: raise def recv(self, buffer_size): try: data = self.socket.recv(buffer_size) if not data: # a closed connection is indicated by signaling # a read condition, and having recv() return 0. self.handle_close() return '' else: return data except socket.error, why: # winsock sometimes raises ENOTCONN if why.args[0] in _DISCONNECTED: self.handle_close() return '' else: raise def close(self): self.connected = False self.accepting = False self.connecting = False self.del_channel() try: self.socket.close() except socket.error, why: if why.args[0] not in (ENOTCONN, EBADF): raise # cheap inheritance, used to pass all other attribute # references to the underlying socket object. def __getattr__(self, attr): try: retattr = getattr(self.socket, attr) except AttributeError: raise AttributeError("%s instance has no attribute '%s'" %(self.__class__.__name__, attr)) else: msg = "%(me)s.%(attr)s is deprecated. Use %(me)s.socket.%(attr)s " \ "instead." % {'me': self.__class__.__name__, 'attr':attr} warnings.warn(msg, DeprecationWarning, stacklevel=2) return retattr # log and log_info may be overridden to provide more sophisticated # logging and warning methods. In general, log is for 'hit' logging # and 'log_info' is for informational, warning and error logging. def log(self, message): sys.stderr.write('log: %s\n' % str(message)) def log_info(self, message, type='info'): if type not in self.ignore_log_types: print '%s: %s' % (type, message) def handle_read_event(self): if self.accepting: # accepting sockets are never connected, they "spawn" new # sockets that are connected self.handle_accept() elif not self.connected: if self.connecting: self.handle_connect_event() self.handle_read() else: self.handle_read() def handle_connect_event(self): err = self.socket.getsockopt(socket.SOL_SOCKET, socket.SO_ERROR) if err != 0: raise socket.error(err, _strerror(err)) self.handle_connect() self.connected = True self.connecting = False def handle_write_event(self): if self.accepting: # Accepting sockets shouldn't get a write event. # We will pretend it didn't happen. return if not self.connected: if self.connecting: self.handle_connect_event() self.handle_write() def handle_expt_event(self): # handle_expt_event() is called if there might be an error on the # socket, or if there is OOB data # check for the error condition first err = self.socket.getsockopt(socket.SOL_SOCKET, socket.SO_ERROR) if err != 0: # we can get here when select.select() says that there is an # exceptional condition on the socket # since there is an error, we'll go ahead and close the socket # like we would in a subclassed handle_read() that received no # data self.handle_close() else: self.handle_expt() def handle_error(self): nil, t, v, tbinfo = compact_traceback() # sometimes a user repr method will crash. try: self_repr = repr(self) except: self_repr = '<__repr__(self) failed for object at %0x>' % id(self) self.log_info( 'uncaptured python exception, closing channel %s (%s:%s %s)' % ( self_repr, t, v, tbinfo ), 'error' ) self.handle_close() def handle_expt(self): self.log_info('unhandled incoming priority event', 'warning') def handle_read(self): self.log_info('unhandled read event', 'warning') def handle_write(self): self.log_info('unhandled write event', 'warning') def handle_connect(self): self.log_info('unhandled connect event', 'warning') def handle_accept(self): self.log_info('unhandled accept event', 'warning') def handle_close(self): self.log_info('unhandled close event', 'warning') self.close() # --------------------------------------------------------------------------- # adds simple buffered output capability, useful for simple clients. # [for more sophisticated usage use asynchat.async_chat] # --------------------------------------------------------------------------- class dispatcher_with_send(dispatcher): def __init__(self, sock=None, map=None): dispatcher.__init__(self, sock, map) self.out_buffer = '' def initiate_send(self): num_sent = 0 num_sent = dispatcher.send(self, self.out_buffer[:512]) self.out_buffer = self.out_buffer[num_sent:] def handle_write(self): self.initiate_send() def writable(self): return (not self.connected) or len(self.out_buffer) def send(self, data): if self.debug: self.log_info('sending %s' % repr(data)) self.out_buffer = self.out_buffer + data self.initiate_send() # --------------------------------------------------------------------------- # used for debugging. # --------------------------------------------------------------------------- def compact_traceback(): t, v, tb = sys.exc_info() tbinfo = [] if not tb: # Must have a traceback raise AssertionError("traceback does not exist") while tb: tbinfo.append(( tb.tb_frame.f_code.co_filename, tb.tb_frame.f_code.co_name, str(tb.tb_lineno) )) tb = tb.tb_next # just to be safe del tb file, function, line = tbinfo[-1] info = ' '.join(['[%s|%s|%s]' % x for x in tbinfo]) return (file, function, line), t, v, info def close_all(map=None, ignore_all=False): if map is None: map = socket_map for x in map.values(): try: x.close() except OSError, x: if x.args[0] == EBADF: pass elif not ignore_all: raise except _reraised_exceptions: raise except: if not ignore_all: raise map.clear() # Asynchronous File I/O: # # After a little research (reading man pages on various unixen, and # digging through the linux kernel), I've determined that select() # isn't meant for doing asynchronous file i/o. # Heartening, though - reading linux/mm/filemap.c shows that linux # supports asynchronous read-ahead. So _MOST_ of the time, the data # will be sitting in memory for us already when we go to read it. # # What other OS's (besides NT) support async file i/o? [VMS?] # # Regardless, this is useful for pipes, and stdin/stdout... if os.name == 'posix': import fcntl class file_wrapper: # Here we override just enough to make a file # look like a socket for the purposes of asyncore. # The passed fd is automatically os.dup()'d def __init__(self, fd): self.fd = os.dup(fd) def recv(self, *args): return os.read(self.fd, *args) def send(self, *args): return os.write(self.fd, *args) def getsockopt(self, level, optname, buflen=None): if (level == socket.SOL_SOCKET and optname == socket.SO_ERROR and not buflen): return 0 raise NotImplementedError("Only asyncore specific behaviour " "implemented.") read = recv write = send def close(self): if self.fd < 0: return fd = self.fd self.fd = -1 os.close(fd) def fileno(self): return self.fd class file_dispatcher(dispatcher): def __init__(self, fd, map=None): dispatcher.__init__(self, None, map) self.connected = True try: fd = fd.fileno() except AttributeError: pass self.set_file(fd) # set it to non-blocking mode flags = fcntl.fcntl(fd, fcntl.F_GETFL, 0) flags = flags | os.O_NONBLOCK fcntl.fcntl(fd, fcntl.F_SETFL, flags) def set_file(self, fd): self.socket = file_wrapper(fd) self._fileno = self.socket.fileno() self.add_channel()
Upload File
Create Folder