X7ROOT File Manager
Current Path:
/lib64/python2.7
lib64
/
python2.7
/
??
..
??
BaseHTTPServer.py
(22.21 KB)
??
BaseHTTPServer.pyc
(21.21 KB)
??
BaseHTTPServer.pyo
(21.21 KB)
??
Bastion.py
(5.61 KB)
??
Bastion.pyc
(6.5 KB)
??
Bastion.pyo
(6.5 KB)
??
CGIHTTPServer.py
(12.78 KB)
??
CGIHTTPServer.pyc
(10.76 KB)
??
CGIHTTPServer.pyo
(10.76 KB)
??
ConfigParser.py
(27.1 KB)
??
ConfigParser.pyc
(24.62 KB)
??
ConfigParser.pyo
(24.62 KB)
??
Cookie.py
(25.92 KB)
??
Cookie.pyc
(22.13 KB)
??
Cookie.pyo
(22.13 KB)
??
Demo
??
Doc
??
DocXMLRPCServer.py
(10.52 KB)
??
DocXMLRPCServer.pyc
(9.96 KB)
??
DocXMLRPCServer.pyo
(9.85 KB)
??
HTMLParser.py
(16.77 KB)
??
HTMLParser.pyc
(13.41 KB)
??
HTMLParser.pyo
(13.11 KB)
??
MimeWriter.py
(6.33 KB)
??
MimeWriter.pyc
(7.19 KB)
??
MimeWriter.pyo
(7.19 KB)
??
Queue.py
(8.38 KB)
??
Queue.pyc
(9.2 KB)
??
Queue.pyo
(9.2 KB)
??
SimpleHTTPServer.py
(7.81 KB)
??
SimpleHTTPServer.pyc
(7.82 KB)
??
SimpleHTTPServer.pyo
(7.82 KB)
??
SimpleXMLRPCServer.py
(25.21 KB)
??
SimpleXMLRPCServer.pyc
(22.33 KB)
??
SimpleXMLRPCServer.pyo
(22.33 KB)
??
SocketServer.py
(23.39 KB)
??
SocketServer.pyc
(23.52 KB)
??
SocketServer.pyo
(23.52 KB)
??
StringIO.py
(10.41 KB)
??
StringIO.pyc
(11.21 KB)
??
StringIO.pyo
(11.21 KB)
??
Tools
??
UserDict.py
(6.89 KB)
??
UserDict.pyc
(9.48 KB)
??
UserDict.pyo
(9.48 KB)
??
UserList.py
(3.56 KB)
??
UserList.pyc
(6.42 KB)
??
UserList.pyo
(6.42 KB)
??
UserString.py
(9.46 KB)
??
UserString.pyc
(14.52 KB)
??
UserString.pyo
(14.52 KB)
??
_LWPCookieJar.py
(6.4 KB)
??
_LWPCookieJar.pyc
(5.31 KB)
??
_LWPCookieJar.pyo
(5.31 KB)
??
_MozillaCookieJar.py
(5.66 KB)
??
_MozillaCookieJar.pyc
(4.36 KB)
??
_MozillaCookieJar.pyo
(4.32 KB)
??
__future__.py
(4.28 KB)
??
__future__.pyc
(4.12 KB)
??
__future__.pyo
(4.12 KB)
??
__phello__.foo.py
(64 B)
??
__phello__.foo.pyc
(125 B)
??
__phello__.foo.pyo
(125 B)
??
_abcoll.py
(18.18 KB)
??
_abcoll.pyc
(25.08 KB)
??
_abcoll.pyo
(25.08 KB)
??
_osx_support.py
(18.65 KB)
??
_osx_support.pyc
(11.48 KB)
??
_osx_support.pyo
(11.48 KB)
??
_pyio.py
(68 KB)
??
_pyio.pyc
(63.18 KB)
??
_pyio.pyo
(63.18 KB)
??
_strptime.py
(20.24 KB)
??
_strptime.pyc
(14.82 KB)
??
_strptime.pyo
(14.82 KB)
??
_sysconfigdata.py
(19.27 KB)
??
_sysconfigdata.pyc
(22.43 KB)
??
_sysconfigdata.pyo
(22.43 KB)
??
_threading_local.py
(7.09 KB)
??
_threading_local.pyc
(6.22 KB)
??
_threading_local.pyo
(6.22 KB)
??
_weakrefset.py
(5.77 KB)
??
_weakrefset.pyc
(9.45 KB)
??
_weakrefset.pyo
(9.45 KB)
??
abc.py
(6.98 KB)
??
abc.pyc
(6 KB)
??
abc.pyo
(5.94 KB)
??
aifc.py
(33.77 KB)
??
aifc.pyc
(29.75 KB)
??
aifc.pyo
(29.75 KB)
??
antigravity.py
(60 B)
??
antigravity.pyc
(203 B)
??
antigravity.pyo
(203 B)
??
anydbm.py
(2.6 KB)
??
anydbm.pyc
(2.73 KB)
??
anydbm.pyo
(2.73 KB)
??
argparse.py
(87.14 KB)
??
argparse.pyc
(62.86 KB)
??
argparse.pyo
(62.7 KB)
??
ast.py
(11.53 KB)
??
ast.pyc
(12.63 KB)
??
ast.pyo
(12.63 KB)
??
asynchat.py
(11.31 KB)
??
asynchat.pyc
(8.6 KB)
??
asynchat.pyo
(8.6 KB)
??
asyncore.py
(20.45 KB)
??
asyncore.pyc
(18.45 KB)
??
asyncore.pyo
(18.45 KB)
??
atexit.py
(1.67 KB)
??
atexit.pyc
(2.15 KB)
??
atexit.pyo
(2.15 KB)
??
audiodev.py
(7.42 KB)
??
audiodev.pyc
(8.27 KB)
??
audiodev.pyo
(8.27 KB)
??
base64.py
(11.53 KB)
??
base64.pyc
(11.03 KB)
??
base64.pyo
(11.03 KB)
??
bdb.py
(21.21 KB)
??
bdb.pyc
(18.65 KB)
??
bdb.pyo
(18.65 KB)
??
binhex.py
(14.35 KB)
??
binhex.pyc
(15.1 KB)
??
binhex.pyo
(15.1 KB)
??
bisect.py
(2.53 KB)
??
bisect.pyc
(3 KB)
??
bisect.pyo
(3 KB)
??
bsddb
??
cProfile.py
(6.42 KB)
??
cProfile.pyc
(6.25 KB)
??
cProfile.pyo
(6.25 KB)
??
calendar.py
(22.84 KB)
??
calendar.pyc
(27.26 KB)
??
calendar.pyo
(27.26 KB)
??
cgi.py
(35.46 KB)
??
cgi.pyc
(32.58 KB)
??
cgi.pyo
(32.58 KB)
??
cgitb.py
(11.89 KB)
??
cgitb.pyc
(11.85 KB)
??
cgitb.pyo
(11.85 KB)
??
chunk.py
(5.29 KB)
??
chunk.pyc
(5.47 KB)
??
chunk.pyo
(5.47 KB)
??
cmd.py
(14.67 KB)
??
cmd.pyc
(13.71 KB)
??
cmd.pyo
(13.71 KB)
??
code.py
(9.95 KB)
??
code.pyc
(10.09 KB)
??
code.pyo
(10.09 KB)
??
codecs.py
(35.3 KB)
??
codecs.pyc
(35.96 KB)
??
codecs.pyo
(35.96 KB)
??
codeop.py
(5.86 KB)
??
codeop.pyc
(6.44 KB)
??
codeop.pyo
(6.44 KB)
??
collections.py
(27.15 KB)
??
collections.pyc
(25.55 KB)
??
collections.pyo
(25.5 KB)
??
colorsys.py
(3.6 KB)
??
colorsys.pyc
(3.9 KB)
??
colorsys.pyo
(3.9 KB)
??
commands.py
(2.49 KB)
??
commands.pyc
(2.41 KB)
??
commands.pyo
(2.41 KB)
??
compileall.py
(7.58 KB)
??
compileall.pyc
(6.85 KB)
??
compileall.pyo
(6.85 KB)
??
compiler
??
config
??
contextlib.py
(4.32 KB)
??
contextlib.pyc
(4.35 KB)
??
contextlib.pyo
(4.35 KB)
??
cookielib.py
(63.95 KB)
??
cookielib.pyc
(53.44 KB)
??
cookielib.pyo
(53.26 KB)
??
copy.py
(11.26 KB)
??
copy.pyc
(11.88 KB)
??
copy.pyo
(11.79 KB)
??
copy_reg.py
(6.81 KB)
??
copy_reg.pyc
(5.05 KB)
??
copy_reg.pyo
(5 KB)
??
crypt.py
(2.24 KB)
??
crypt.pyc
(2.89 KB)
??
crypt.pyo
(2.89 KB)
??
csv.py
(16.32 KB)
??
csv.pyc
(13.19 KB)
??
csv.pyo
(13.19 KB)
??
ctypes
??
curses
??
dbhash.py
(498 B)
??
dbhash.pyc
(718 B)
??
dbhash.pyo
(718 B)
??
decimal.py
(216.73 KB)
??
decimal.pyc
(168.12 KB)
??
decimal.pyo
(168.12 KB)
??
difflib.py
(80.4 KB)
??
difflib.pyc
(60.45 KB)
??
difflib.pyo
(60.4 KB)
??
dircache.py
(1.1 KB)
??
dircache.pyc
(1.54 KB)
??
dircache.pyo
(1.54 KB)
??
dis.py
(6.35 KB)
??
dis.pyc
(6.08 KB)
??
dis.pyo
(6.08 KB)
??
distutils
??
doctest.py
(102.63 KB)
??
doctest.pyc
(81.68 KB)
??
doctest.pyo
(81.4 KB)
??
dumbdbm.py
(8.93 KB)
??
dumbdbm.pyc
(6.59 KB)
??
dumbdbm.pyo
(6.59 KB)
??
dummy_thread.py
(4.31 KB)
??
dummy_thread.pyc
(5.27 KB)
??
dummy_thread.pyo
(5.27 KB)
??
dummy_threading.py
(2.74 KB)
??
dummy_threading.pyc
(1.25 KB)
??
dummy_threading.pyo
(1.25 KB)
??
email
??
encodings
??
ensurepip
??
filecmp.py
(9.36 KB)
??
filecmp.pyc
(9.4 KB)
??
filecmp.pyo
(9.4 KB)
??
fileinput.py
(13.42 KB)
??
fileinput.pyc
(14.16 KB)
??
fileinput.pyo
(14.16 KB)
??
fnmatch.py
(3.24 KB)
??
fnmatch.pyc
(3.53 KB)
??
fnmatch.pyo
(3.53 KB)
??
formatter.py
(14.56 KB)
??
formatter.pyc
(18.73 KB)
??
formatter.pyo
(18.73 KB)
??
fpformat.py
(4.62 KB)
??
fpformat.pyc
(4.59 KB)
??
fpformat.pyo
(4.59 KB)
??
fractions.py
(21.87 KB)
??
fractions.pyc
(19.25 KB)
??
fractions.pyo
(19.25 KB)
??
ftplib.py
(37.65 KB)
??
ftplib.pyc
(34.12 KB)
??
ftplib.pyo
(34.12 KB)
??
functools.py
(4.69 KB)
??
functools.pyc
(6.47 KB)
??
functools.pyo
(6.47 KB)
??
genericpath.py
(3.13 KB)
??
genericpath.pyc
(3.43 KB)
??
genericpath.pyo
(3.43 KB)
??
getopt.py
(7.15 KB)
??
getopt.pyc
(6.5 KB)
??
getopt.pyo
(6.45 KB)
??
getpass.py
(5.43 KB)
??
getpass.pyc
(4.63 KB)
??
getpass.pyo
(4.63 KB)
??
gettext.py
(22.13 KB)
??
gettext.pyc
(17.58 KB)
??
gettext.pyo
(17.58 KB)
??
glob.py
(3.04 KB)
??
glob.pyc
(2.87 KB)
??
glob.pyo
(2.87 KB)
??
gzip.py
(18.58 KB)
??
gzip.pyc
(14.88 KB)
??
gzip.pyo
(14.88 KB)
??
hashlib.py
(7.66 KB)
??
hashlib.pyc
(6.76 KB)
??
hashlib.pyo
(6.76 KB)
??
heapq.py
(17.87 KB)
??
heapq.pyc
(14.22 KB)
??
heapq.pyo
(14.22 KB)
??
hmac.py
(4.48 KB)
??
hmac.pyc
(4.44 KB)
??
hmac.pyo
(4.44 KB)
??
hotshot
??
htmlentitydefs.py
(17.63 KB)
??
htmlentitydefs.pyc
(6.22 KB)
??
htmlentitydefs.pyo
(6.22 KB)
??
htmllib.py
(12.57 KB)
??
htmllib.pyc
(19.83 KB)
??
htmllib.pyo
(19.83 KB)
??
httplib.py
(52.06 KB)
??
httplib.pyc
(37.82 KB)
??
httplib.pyo
(37.64 KB)
??
idlelib
??
ihooks.py
(18.54 KB)
??
ihooks.pyc
(20.87 KB)
??
ihooks.pyo
(20.87 KB)
??
imaplib.py
(47.23 KB)
??
imaplib.pyc
(43.96 KB)
??
imaplib.pyo
(41.32 KB)
??
imghdr.py
(3.46 KB)
??
imghdr.pyc
(4.72 KB)
??
imghdr.pyo
(4.72 KB)
??
importlib
??
imputil.py
(25.16 KB)
??
imputil.pyc
(15.26 KB)
??
imputil.pyo
(15.08 KB)
??
inspect.py
(42 KB)
??
inspect.pyc
(39.29 KB)
??
inspect.pyo
(39.29 KB)
??
io.py
(3.24 KB)
??
io.pyc
(3.5 KB)
??
io.pyo
(3.5 KB)
??
json
??
keyword.py
(1.95 KB)
??
keyword.pyc
(2.06 KB)
??
keyword.pyo
(2.06 KB)
??
lib-dynload
??
lib-tk
??
lib2to3
??
linecache.py
(3.93 KB)
??
linecache.pyc
(3.2 KB)
??
linecache.pyo
(3.2 KB)
??
locale.py
(100.42 KB)
??
locale.pyc
(55.28 KB)
??
locale.pyo
(55.28 KB)
??
logging
??
macpath.py
(6.14 KB)
??
macpath.pyc
(7.5 KB)
??
macpath.pyo
(7.5 KB)
??
macurl2path.py
(2.67 KB)
??
macurl2path.pyc
(2.19 KB)
??
macurl2path.pyo
(2.19 KB)
??
mailbox.py
(79.34 KB)
??
mailbox.pyc
(74.92 KB)
??
mailbox.pyo
(74.87 KB)
??
mailcap.py
(8.21 KB)
??
mailcap.pyc
(7.77 KB)
??
mailcap.pyo
(7.77 KB)
??
markupbase.py
(14.3 KB)
??
markupbase.pyc
(9.05 KB)
??
markupbase.pyo
(8.86 KB)
??
md5.py
(358 B)
??
md5.pyc
(378 B)
??
md5.pyo
(378 B)
??
mhlib.py
(32.65 KB)
??
mhlib.pyc
(32.99 KB)
??
mhlib.pyo
(32.99 KB)
??
mimetools.py
(7 KB)
??
mimetools.pyc
(8.01 KB)
??
mimetools.pyo
(8.01 KB)
??
mimetypes.py
(20.54 KB)
??
mimetypes.pyc
(18.06 KB)
??
mimetypes.pyo
(18.06 KB)
??
mimify.py
(14.67 KB)
??
mimify.pyc
(11.72 KB)
??
mimify.pyo
(11.72 KB)
??
modulefinder.py
(23.89 KB)
??
modulefinder.pyc
(18.68 KB)
??
modulefinder.pyo
(18.6 KB)
??
multifile.py
(4.71 KB)
??
multifile.pyc
(5.29 KB)
??
multifile.pyo
(5.25 KB)
??
multiprocessing
??
mutex.py
(1.83 KB)
??
mutex.pyc
(2.46 KB)
??
mutex.pyo
(2.46 KB)
??
netrc.py
(5.75 KB)
??
netrc.pyc
(4.6 KB)
??
netrc.pyo
(4.6 KB)
??
new.py
(610 B)
??
new.pyc
(862 B)
??
new.pyo
(862 B)
??
nntplib.py
(20.97 KB)
??
nntplib.pyc
(20.55 KB)
??
nntplib.pyo
(20.55 KB)
??
ntpath.py
(18.97 KB)
??
ntpath.pyc
(12.82 KB)
??
ntpath.pyo
(12.82 KB)
??
nturl2path.py
(2.36 KB)
??
nturl2path.pyc
(1.77 KB)
??
nturl2path.pyo
(1.77 KB)
??
numbers.py
(10.08 KB)
??
numbers.pyc
(13.68 KB)
??
numbers.pyo
(13.68 KB)
??
opcode.py
(5.35 KB)
??
opcode.pyc
(6 KB)
??
opcode.pyo
(6 KB)
??
optparse.py
(59.77 KB)
??
optparse.pyc
(52.63 KB)
??
optparse.pyo
(52.55 KB)
??
os.py
(25.3 KB)
??
os.pyc
(25.09 KB)
??
os.pyo
(25.09 KB)
??
os2emxpath.py
(4.53 KB)
??
os2emxpath.pyc
(4.42 KB)
??
os2emxpath.pyo
(4.42 KB)
??
pdb.doc
(7.73 KB)
??
pdb.py
(45.02 KB)
??
pdb.pyc
(42.65 KB)
??
pdb.pyo
(42.65 KB)
??
pickle.py
(44.42 KB)
??
pickle.pyc
(37.66 KB)
??
pickle.pyo
(37.46 KB)
??
pickletools.py
(72.78 KB)
??
pickletools.pyc
(55.7 KB)
??
pickletools.pyo
(54.85 KB)
??
pipes.py
(9.36 KB)
??
pipes.pyc
(9.09 KB)
??
pipes.pyo
(9.09 KB)
??
pkgutil.py
(19.77 KB)
??
pkgutil.pyc
(18.51 KB)
??
pkgutil.pyo
(18.51 KB)
??
plat-linux2
??
platform.py
(51.56 KB)
??
platform.pyc
(37.08 KB)
??
platform.pyo
(37.08 KB)
??
plistlib.py
(15.44 KB)
??
plistlib.pyc
(19.5 KB)
??
plistlib.pyo
(19.41 KB)
??
popen2.py
(8.22 KB)
??
popen2.pyc
(8.81 KB)
??
popen2.pyo
(8.77 KB)
??
poplib.py
(12.52 KB)
??
poplib.pyc
(13.03 KB)
??
poplib.pyo
(13.03 KB)
??
posixfile.py
(7.82 KB)
??
posixfile.pyc
(7.47 KB)
??
posixfile.pyo
(7.47 KB)
??
posixpath.py
(13.96 KB)
??
posixpath.pyc
(11.19 KB)
??
posixpath.pyo
(11.19 KB)
??
pprint.py
(11.5 KB)
??
pprint.pyc
(9.96 KB)
??
pprint.pyo
(9.78 KB)
??
profile.py
(22.25 KB)
??
profile.pyc
(16.07 KB)
??
profile.pyo
(15.83 KB)
??
pstats.py
(26.09 KB)
??
pstats.pyc
(24.43 KB)
??
pstats.pyo
(24.43 KB)
??
pty.py
(4.94 KB)
??
pty.pyc
(4.85 KB)
??
pty.pyo
(4.85 KB)
??
py_compile.py
(5.8 KB)
??
py_compile.pyc
(6.28 KB)
??
py_compile.pyo
(6.28 KB)
??
pyclbr.py
(13.07 KB)
??
pyclbr.pyc
(9.42 KB)
??
pyclbr.pyo
(9.42 KB)
??
pydoc.py
(93.5 KB)
??
pydoc.pyc
(90.18 KB)
??
pydoc.pyo
(90.12 KB)
??
pydoc_data
??
quopri.py
(6.8 KB)
??
quopri.pyc
(6.42 KB)
??
quopri.pyo
(6.42 KB)
??
random.py
(31.7 KB)
??
random.pyc
(25.1 KB)
??
random.pyo
(25.1 KB)
??
re.py
(13.11 KB)
??
re.pyc
(13.1 KB)
??
re.pyo
(13.1 KB)
??
repr.py
(4.2 KB)
??
repr.pyc
(5.26 KB)
??
repr.pyo
(5.26 KB)
??
rexec.py
(19.68 KB)
??
rexec.pyc
(23.25 KB)
??
rexec.pyo
(23.25 KB)
??
rfc822.py
(32.76 KB)
??
rfc822.pyc
(31.07 KB)
??
rfc822.pyo
(31.07 KB)
??
rlcompleter.py
(5.85 KB)
??
rlcompleter.pyc
(5.94 KB)
??
rlcompleter.pyo
(5.94 KB)
??
robotparser.py
(7.51 KB)
??
robotparser.pyc
(7.82 KB)
??
robotparser.pyo
(7.82 KB)
??
runpy.py
(10.82 KB)
??
runpy.pyc
(8.6 KB)
??
runpy.pyo
(8.6 KB)
??
sched.py
(4.97 KB)
??
sched.pyc
(4.88 KB)
??
sched.pyo
(4.88 KB)
??
sets.py
(18.6 KB)
??
sets.pyc
(16.5 KB)
??
sets.pyo
(16.5 KB)
??
sgmllib.py
(17.46 KB)
??
sgmllib.pyc
(15.07 KB)
??
sgmllib.pyo
(15.07 KB)
??
sha.py
(393 B)
??
sha.pyc
(421 B)
??
sha.pyo
(421 B)
??
shelve.py
(7.99 KB)
??
shelve.pyc
(10.02 KB)
??
shelve.pyo
(10.02 KB)
??
shlex.py
(10.9 KB)
??
shlex.pyc
(7.38 KB)
??
shlex.pyo
(7.38 KB)
??
shutil.py
(19.41 KB)
??
shutil.pyc
(18.81 KB)
??
shutil.pyo
(18.81 KB)
??
site-packages
??
site.py
(20.8 KB)
??
site.pyc
(20.3 KB)
??
site.pyo
(20.3 KB)
??
smtpd.py
(18.11 KB)
??
smtpd.pyc
(15.51 KB)
??
smtpd.pyo
(15.51 KB)
??
smtplib.py
(31.38 KB)
??
smtplib.pyc
(29.59 KB)
??
smtplib.pyo
(29.59 KB)
??
sndhdr.py
(5.83 KB)
??
sndhdr.pyc
(7.19 KB)
??
sndhdr.pyo
(7.19 KB)
??
socket.py
(20.13 KB)
??
socket.pyc
(15.77 KB)
??
socket.pyo
(15.69 KB)
??
sqlite3
??
sre.py
(384 B)
??
sre.pyc
(519 B)
??
sre.pyo
(519 B)
??
sre_compile.py
(19.36 KB)
??
sre_compile.pyc
(12.27 KB)
??
sre_compile.pyo
(12.11 KB)
??
sre_constants.py
(7.03 KB)
??
sre_constants.pyc
(6.05 KB)
??
sre_constants.pyo
(6.05 KB)
??
sre_parse.py
(29.98 KB)
??
sre_parse.pyc
(20.66 KB)
??
sre_parse.pyo
(20.66 KB)
??
ssl.py
(38.39 KB)
??
ssl.pyc
(31.95 KB)
??
ssl.pyo
(31.95 KB)
??
stat.py
(1.8 KB)
??
stat.pyc
(2.69 KB)
??
stat.pyo
(2.69 KB)
??
statvfs.py
(898 B)
??
statvfs.pyc
(620 B)
??
statvfs.pyo
(620 B)
??
string.py
(21.04 KB)
??
string.pyc
(19.98 KB)
??
string.pyo
(19.98 KB)
??
stringold.py
(12.16 KB)
??
stringold.pyc
(12.25 KB)
??
stringold.pyo
(12.25 KB)
??
stringprep.py
(13.21 KB)
??
stringprep.pyc
(14.15 KB)
??
stringprep.pyo
(14.08 KB)
??
struct.py
(82 B)
??
struct.pyc
(239 B)
??
struct.pyo
(239 B)
??
subprocess.py
(49.34 KB)
??
subprocess.pyc
(31.64 KB)
??
subprocess.pyo
(31.64 KB)
??
sunau.py
(16.82 KB)
??
sunau.pyc
(17.96 KB)
??
sunau.pyo
(17.96 KB)
??
sunaudio.py
(1.37 KB)
??
sunaudio.pyc
(1.94 KB)
??
sunaudio.pyo
(1.94 KB)
??
symbol.py
(2.01 KB)
??
symbol.pyc
(2.96 KB)
??
symbol.pyo
(2.96 KB)
??
symtable.py
(7.26 KB)
??
symtable.pyc
(11.51 KB)
??
symtable.pyo
(11.38 KB)
??
sysconfig.py
(22.32 KB)
??
sysconfig.pyc
(17.4 KB)
??
sysconfig.pyo
(17.4 KB)
??
tabnanny.py
(11.07 KB)
??
tabnanny.pyc
(8.05 KB)
??
tabnanny.pyo
(8.05 KB)
??
tarfile.py
(88.53 KB)
??
tarfile.pyc
(74.41 KB)
??
tarfile.pyo
(74.41 KB)
??
telnetlib.py
(26.4 KB)
??
telnetlib.pyc
(22.61 KB)
??
telnetlib.pyo
(22.61 KB)
??
tempfile.py
(19.09 KB)
??
tempfile.pyc
(19.87 KB)
??
tempfile.pyo
(19.87 KB)
??
test
??
textwrap.py
(16.88 KB)
??
textwrap.pyc
(11.81 KB)
??
textwrap.pyo
(11.72 KB)
??
this.py
(1002 B)
??
this.pyc
(1.19 KB)
??
this.pyo
(1.19 KB)
??
threading.py
(46.27 KB)
??
threading.pyc
(41.72 KB)
??
threading.pyo
(39.6 KB)
??
timeit.py
(12.49 KB)
??
timeit.pyc
(11.9 KB)
??
timeit.pyo
(11.9 KB)
??
toaiff.py
(3.07 KB)
??
toaiff.pyc
(3.03 KB)
??
toaiff.pyo
(3.03 KB)
??
token.py
(2.85 KB)
??
token.pyc
(3.73 KB)
??
token.pyo
(3.73 KB)
??
tokenize.py
(17.07 KB)
??
tokenize.pyc
(14.17 KB)
??
tokenize.pyo
(14.11 KB)
??
trace.py
(29.19 KB)
??
trace.pyc
(22.26 KB)
??
trace.pyo
(22.2 KB)
??
traceback.py
(11.02 KB)
??
traceback.pyc
(11.41 KB)
??
traceback.pyo
(11.41 KB)
??
tty.py
(879 B)
??
tty.pyc
(1.29 KB)
??
tty.pyo
(1.29 KB)
??
types.py
(2.04 KB)
??
types.pyc
(2.66 KB)
??
types.pyo
(2.66 KB)
??
unittest
??
urllib.py
(58.82 KB)
??
urllib.pyc
(50.04 KB)
??
urllib.pyo
(49.95 KB)
??
urllib2.py
(51.31 KB)
??
urllib2.pyc
(46.19 KB)
??
urllib2.pyo
(46.1 KB)
??
urlparse.py
(19.98 KB)
??
urlparse.pyc
(17.59 KB)
??
urlparse.pyo
(17.59 KB)
??
user.py
(1.59 KB)
??
user.pyc
(1.68 KB)
??
user.pyo
(1.68 KB)
??
uu.py
(6.54 KB)
??
uu.pyc
(4.29 KB)
??
uu.pyo
(4.29 KB)
??
uuid.py
(22.98 KB)
??
uuid.pyc
(22.82 KB)
??
uuid.pyo
(22.71 KB)
??
warnings.py
(14.48 KB)
??
warnings.pyc
(13.19 KB)
??
warnings.pyo
(12.42 KB)
??
wave.py
(18.15 KB)
??
wave.pyc
(19.54 KB)
??
wave.pyo
(19.4 KB)
??
weakref.py
(14.48 KB)
??
weakref.pyc
(16.06 KB)
??
weakref.pyo
(16.06 KB)
??
webbrowser.py
(22.19 KB)
??
webbrowser.pyc
(19.29 KB)
??
webbrowser.pyo
(19.24 KB)
??
whichdb.py
(3.3 KB)
??
whichdb.pyc
(2.19 KB)
??
whichdb.pyo
(2.19 KB)
??
wsgiref
??
wsgiref.egg-info
(187 B)
??
xdrlib.py
(5.93 KB)
??
xdrlib.pyc
(9.67 KB)
??
xdrlib.pyo
(9.67 KB)
??
xml
??
xmllib.py
(34.05 KB)
??
xmllib.pyc
(26.22 KB)
??
xmllib.pyo
(26.22 KB)
??
xmlrpclib.py
(50.91 KB)
??
xmlrpclib.pyc
(43.07 KB)
??
xmlrpclib.pyo
(42.89 KB)
??
zipfile.py
(58.08 KB)
??
zipfile.pyc
(41.15 KB)
??
zipfile.pyo
(41.15 KB)
Editing: modulefinder.py
"""Find modules used by a script, using introspection.""" from __future__ import generators import dis import imp import marshal import os import sys import types import struct if hasattr(sys.__stdout__, "newlines"): READ_MODE = "U" # universal line endings else: # Python < 2.3 compatibility, no longer strictly required READ_MODE = "r" LOAD_CONST = dis.opmap['LOAD_CONST'] IMPORT_NAME = dis.opmap['IMPORT_NAME'] STORE_NAME = dis.opmap['STORE_NAME'] STORE_GLOBAL = dis.opmap['STORE_GLOBAL'] STORE_OPS = STORE_NAME, STORE_GLOBAL HAVE_ARGUMENT = dis.HAVE_ARGUMENT EXTENDED_ARG = dis.EXTENDED_ARG def _unpack_opargs(code): # enumerate() is not an option, since we sometimes process # multiple elements on a single pass through the loop extended_arg = 0 n = len(code) i = 0 while i < n: op = ord(code[i]) offset = i i = i+1 arg = None if op >= HAVE_ARGUMENT: arg = ord(code[i]) + ord(code[i+1])*256 + extended_arg extended_arg = 0 i = i+2 if op == EXTENDED_ARG: extended_arg = arg*65536 yield (offset, op, arg) # Modulefinder does a good job at simulating Python's, but it can not # handle __path__ modifications packages make at runtime. Therefore there # is a mechanism whereby you can register extra paths in this map for a # package, and it will be honored. # Note this is a mapping is lists of paths. packagePathMap = {} # A Public interface def AddPackagePath(packagename, path): paths = packagePathMap.get(packagename, []) paths.append(path) packagePathMap[packagename] = paths replacePackageMap = {} # This ReplacePackage mechanism allows modulefinder to work around the # way the _xmlplus package injects itself under the name "xml" into # sys.modules at runtime by calling ReplacePackage("_xmlplus", "xml") # before running ModuleFinder. def ReplacePackage(oldname, newname): replacePackageMap[oldname] = newname class Module: def __init__(self, name, file=None, path=None): self.__name__ = name self.__file__ = file self.__path__ = path self.__code__ = None # The set of global names that are assigned to in the module. # This includes those names imported through starimports of # Python modules. self.globalnames = {} # The set of starimports this module did that could not be # resolved, ie. a starimport from a non-Python module. self.starimports = {} def __repr__(self): s = "Module(%r" % (self.__name__,) if self.__file__ is not None: s = s + ", %r" % (self.__file__,) if self.__path__ is not None: s = s + ", %r" % (self.__path__,) s = s + ")" return s class ModuleFinder: def __init__(self, path=None, debug=0, excludes=[], replace_paths=[]): if path is None: path = sys.path self.path = path self.modules = {} self.badmodules = {} self.debug = debug self.indent = 0 self.excludes = excludes self.replace_paths = replace_paths self.processed_paths = [] # Used in debugging only def msg(self, level, str, *args): if level <= self.debug: for i in range(self.indent): print " ", print str, for arg in args: print repr(arg), print def msgin(self, *args): level = args[0] if level <= self.debug: self.indent = self.indent + 1 self.msg(*args) def msgout(self, *args): level = args[0] if level <= self.debug: self.indent = self.indent - 1 self.msg(*args) def run_script(self, pathname): self.msg(2, "run_script", pathname) with open(pathname, READ_MODE) as fp: stuff = ("", "r", imp.PY_SOURCE) self.load_module('__main__', fp, pathname, stuff) def load_file(self, pathname): dir, name = os.path.split(pathname) name, ext = os.path.splitext(name) with open(pathname, READ_MODE) as fp: stuff = (ext, "r", imp.PY_SOURCE) self.load_module(name, fp, pathname, stuff) def import_hook(self, name, caller=None, fromlist=None, level=-1): self.msg(3, "import_hook", name, caller, fromlist, level) parent = self.determine_parent(caller, level=level) q, tail = self.find_head_package(parent, name) m = self.load_tail(q, tail) if not fromlist: return q if m.__path__: self.ensure_fromlist(m, fromlist) return None def determine_parent(self, caller, level=-1): self.msgin(4, "determine_parent", caller, level) if not caller or level == 0: self.msgout(4, "determine_parent -> None") return None pname = caller.__name__ if level >= 1: # relative import if caller.__path__: level -= 1 if level == 0: parent = self.modules[pname] assert parent is caller self.msgout(4, "determine_parent ->", parent) return parent if pname.count(".") < level: raise ImportError, "relative importpath too deep" pname = ".".join(pname.split(".")[:-level]) parent = self.modules[pname] self.msgout(4, "determine_parent ->", parent) return parent if caller.__path__: parent = self.modules[pname] assert caller is parent self.msgout(4, "determine_parent ->", parent) return parent if '.' in pname: i = pname.rfind('.') pname = pname[:i] parent = self.modules[pname] assert parent.__name__ == pname self.msgout(4, "determine_parent ->", parent) return parent self.msgout(4, "determine_parent -> None") return None def find_head_package(self, parent, name): self.msgin(4, "find_head_package", parent, name) if '.' in name: i = name.find('.') head = name[:i] tail = name[i+1:] else: head = name tail = "" if parent: qname = "%s.%s" % (parent.__name__, head) else: qname = head q = self.import_module(head, qname, parent) if q: self.msgout(4, "find_head_package ->", (q, tail)) return q, tail if parent: qname = head parent = None q = self.import_module(head, qname, parent) if q: self.msgout(4, "find_head_package ->", (q, tail)) return q, tail self.msgout(4, "raise ImportError: No module named", qname) raise ImportError, "No module named " + qname def load_tail(self, q, tail): self.msgin(4, "load_tail", q, tail) m = q while tail: i = tail.find('.') if i < 0: i = len(tail) head, tail = tail[:i], tail[i+1:] mname = "%s.%s" % (m.__name__, head) m = self.import_module(head, mname, m) if not m: self.msgout(4, "raise ImportError: No module named", mname) raise ImportError, "No module named " + mname self.msgout(4, "load_tail ->", m) return m def ensure_fromlist(self, m, fromlist, recursive=0): self.msg(4, "ensure_fromlist", m, fromlist, recursive) for sub in fromlist: if sub == "*": if not recursive: all = self.find_all_submodules(m) if all: self.ensure_fromlist(m, all, 1) elif not hasattr(m, sub): subname = "%s.%s" % (m.__name__, sub) submod = self.import_module(sub, subname, m) if not submod: raise ImportError, "No module named " + subname def find_all_submodules(self, m): if not m.__path__: return modules = {} # 'suffixes' used to be a list hardcoded to [".py", ".pyc", ".pyo"]. # But we must also collect Python extension modules - although # we cannot separate normal dlls from Python extensions. suffixes = [] for triple in imp.get_suffixes(): suffixes.append(triple[0]) for dir in m.__path__: try: names = os.listdir(dir) except os.error: self.msg(2, "can't list directory", dir) continue for name in names: mod = None for suff in suffixes: n = len(suff) if name[-n:] == suff: mod = name[:-n] break if mod and mod != "__init__": modules[mod] = mod return modules.keys() def import_module(self, partname, fqname, parent): self.msgin(3, "import_module", partname, fqname, parent) try: m = self.modules[fqname] except KeyError: pass else: self.msgout(3, "import_module ->", m) return m if fqname in self.badmodules: self.msgout(3, "import_module -> None") return None if parent and parent.__path__ is None: self.msgout(3, "import_module -> None") return None try: fp, pathname, stuff = self.find_module(partname, parent and parent.__path__, parent) except ImportError: self.msgout(3, "import_module ->", None) return None try: m = self.load_module(fqname, fp, pathname, stuff) finally: if fp: fp.close() if parent: setattr(parent, partname, m) self.msgout(3, "import_module ->", m) return m def load_module(self, fqname, fp, pathname, file_info): suffix, mode, type = file_info self.msgin(2, "load_module", fqname, fp and "fp", pathname) if type == imp.PKG_DIRECTORY: m = self.load_package(fqname, pathname) self.msgout(2, "load_module ->", m) return m if type == imp.PY_SOURCE: co = compile(fp.read()+'\n', pathname, 'exec') elif type == imp.PY_COMPILED: if fp.read(4) != imp.get_magic(): self.msgout(2, "raise ImportError: Bad magic number", pathname) raise ImportError, "Bad magic number in %s" % pathname fp.read(4) co = marshal.load(fp) else: co = None m = self.add_module(fqname) m.__file__ = pathname if co: if self.replace_paths: co = self.replace_paths_in_code(co) m.__code__ = co self.scan_code(co, m) self.msgout(2, "load_module ->", m) return m def _add_badmodule(self, name, caller): if name not in self.badmodules: self.badmodules[name] = {} if caller: self.badmodules[name][caller.__name__] = 1 else: self.badmodules[name]["-"] = 1 def _safe_import_hook(self, name, caller, fromlist, level=-1): # wrapper for self.import_hook() that won't raise ImportError if name in self.badmodules: self._add_badmodule(name, caller) return try: self.import_hook(name, caller, level=level) except ImportError, msg: self.msg(2, "ImportError:", str(msg)) self._add_badmodule(name, caller) else: if fromlist: for sub in fromlist: if sub in self.badmodules: self._add_badmodule(sub, caller) continue try: self.import_hook(name, caller, [sub], level=level) except ImportError, msg: self.msg(2, "ImportError:", str(msg)) fullname = name + "." + sub self._add_badmodule(fullname, caller) def scan_opcodes(self, co, unpack = struct.unpack): # Scan the code, and yield 'interesting' opcode combinations # Version for Python 2.4 and older code = co.co_code names = co.co_names consts = co.co_consts opargs = [(op, arg) for _, op, arg in _unpack_opargs(code) if op != EXTENDED_ARG] for i, (op, oparg) in enumerate(opargs): if c in STORE_OPS: yield "store", (names[oparg],) continue if (op == IMPORT_NAME and i >= 1 and opargs[i-1][0] == LOAD_CONST): fromlist = consts[opargs[i-1][1]] yield "import", (fromlist, names[oparg]) continue def scan_opcodes_25(self, co): # Scan the code, and yield 'interesting' opcode combinations code = co.co_code names = co.co_names consts = co.co_consts opargs = [(op, arg) for _, op, arg in _unpack_opargs(code) if op != EXTENDED_ARG] for i, (op, oparg) in enumerate(opargs): if op in STORE_OPS: yield "store", (names[oparg],) continue if (op == IMPORT_NAME and i >= 2 and opargs[i-1][0] == opargs[i-2][0] == LOAD_CONST): level = consts[opargs[i-2][1]] fromlist = consts[opargs[i-1][1]] if level == -1: # normal import yield "import", (fromlist, names[oparg]) elif level == 0: # absolute import yield "absolute_import", (fromlist, names[oparg]) else: # relative import yield "relative_import", (level, fromlist, names[oparg]) continue def scan_code(self, co, m): code = co.co_code if sys.version_info >= (2, 5): scanner = self.scan_opcodes_25 else: scanner = self.scan_opcodes for what, args in scanner(co): if what == "store": name, = args m.globalnames[name] = 1 elif what in ("import", "absolute_import"): fromlist, name = args have_star = 0 if fromlist is not None: if "*" in fromlist: have_star = 1 fromlist = [f for f in fromlist if f != "*"] if what == "absolute_import": level = 0 else: level = -1 self._safe_import_hook(name, m, fromlist, level=level) if have_star: # We've encountered an "import *". If it is a Python module, # the code has already been parsed and we can suck out the # global names. mm = None if m.__path__: # At this point we don't know whether 'name' is a # submodule of 'm' or a global module. Let's just try # the full name first. mm = self.modules.get(m.__name__ + "." + name) if mm is None: mm = self.modules.get(name) if mm is not None: m.globalnames.update(mm.globalnames) m.starimports.update(mm.starimports) if mm.__code__ is None: m.starimports[name] = 1 else: m.starimports[name] = 1 elif what == "relative_import": level, fromlist, name = args if name: self._safe_import_hook(name, m, fromlist, level=level) else: parent = self.determine_parent(m, level=level) self._safe_import_hook(parent.__name__, None, fromlist, level=0) else: # We don't expect anything else from the generator. raise RuntimeError(what) for c in co.co_consts: if isinstance(c, type(co)): self.scan_code(c, m) def load_package(self, fqname, pathname): self.msgin(2, "load_package", fqname, pathname) newname = replacePackageMap.get(fqname) if newname: fqname = newname m = self.add_module(fqname) m.__file__ = pathname m.__path__ = [pathname] # As per comment at top of file, simulate runtime __path__ additions. m.__path__ = m.__path__ + packagePathMap.get(fqname, []) fp, buf, stuff = self.find_module("__init__", m.__path__) self.load_module(fqname, fp, buf, stuff) self.msgout(2, "load_package ->", m) if fp: fp.close() return m def add_module(self, fqname): if fqname in self.modules: return self.modules[fqname] self.modules[fqname] = m = Module(fqname) return m def find_module(self, name, path, parent=None): if parent is not None: # assert path is not None fullname = parent.__name__+'.'+name else: fullname = name if fullname in self.excludes: self.msgout(3, "find_module -> Excluded", fullname) raise ImportError, name if path is None: if name in sys.builtin_module_names: return (None, None, ("", "", imp.C_BUILTIN)) path = self.path return imp.find_module(name, path) def report(self): """Print a report to stdout, listing the found modules with their paths, as well as modules that are missing, or seem to be missing. """ print print " %-25s %s" % ("Name", "File") print " %-25s %s" % ("----", "----") # Print modules found keys = self.modules.keys() keys.sort() for key in keys: m = self.modules[key] if m.__path__: print "P", else: print "m", print "%-25s" % key, m.__file__ or "" # Print missing modules missing, maybe = self.any_missing_maybe() if missing: print print "Missing modules:" for name in missing: mods = self.badmodules[name].keys() mods.sort() print "?", name, "imported from", ', '.join(mods) # Print modules that may be missing, but then again, maybe not... if maybe: print print "Submodules that appear to be missing, but could also be", print "global names in the parent package:" for name in maybe: mods = self.badmodules[name].keys() mods.sort() print "?", name, "imported from", ', '.join(mods) def any_missing(self): """Return a list of modules that appear to be missing. Use any_missing_maybe() if you want to know which modules are certain to be missing, and which *may* be missing. """ missing, maybe = self.any_missing_maybe() return missing + maybe def any_missing_maybe(self): """Return two lists, one with modules that are certainly missing and one with modules that *may* be missing. The latter names could either be submodules *or* just global names in the package. The reason it can't always be determined is that it's impossible to tell which names are imported when "from module import *" is done with an extension module, short of actually importing it. """ missing = [] maybe = [] for name in self.badmodules: if name in self.excludes: continue i = name.rfind(".") if i < 0: missing.append(name) continue subname = name[i+1:] pkgname = name[:i] pkg = self.modules.get(pkgname) if pkg is not None: if pkgname in self.badmodules[name]: # The package tried to import this module itself and # failed. It's definitely missing. missing.append(name) elif subname in pkg.globalnames: # It's a global in the package: definitely not missing. pass elif pkg.starimports: # It could be missing, but the package did an "import *" # from a non-Python module, so we simply can't be sure. maybe.append(name) else: # It's not a global in the package, the package didn't # do funny star imports, it's very likely to be missing. # The symbol could be inserted into the package from the # outside, but since that's not good style we simply list # it missing. missing.append(name) else: missing.append(name) missing.sort() maybe.sort() return missing, maybe def replace_paths_in_code(self, co): new_filename = original_filename = os.path.normpath(co.co_filename) for f, r in self.replace_paths: if original_filename.startswith(f): new_filename = r + original_filename[len(f):] break if self.debug and original_filename not in self.processed_paths: if new_filename != original_filename: self.msgout(2, "co_filename %r changed to %r" \ % (original_filename,new_filename,)) else: self.msgout(2, "co_filename %r remains unchanged" \ % (original_filename,)) self.processed_paths.append(original_filename) consts = list(co.co_consts) for i in range(len(consts)): if isinstance(consts[i], type(co)): consts[i] = self.replace_paths_in_code(consts[i]) return types.CodeType(co.co_argcount, co.co_nlocals, co.co_stacksize, co.co_flags, co.co_code, tuple(consts), co.co_names, co.co_varnames, new_filename, co.co_name, co.co_firstlineno, co.co_lnotab, co.co_freevars, co.co_cellvars) def test(): # Parse command line import getopt try: opts, args = getopt.getopt(sys.argv[1:], "dmp:qx:") except getopt.error, msg: print msg return # Process options debug = 1 domods = 0 addpath = [] exclude = [] for o, a in opts: if o == '-d': debug = debug + 1 if o == '-m': domods = 1 if o == '-p': addpath = addpath + a.split(os.pathsep) if o == '-q': debug = 0 if o == '-x': exclude.append(a) # Provide default arguments if not args: script = "hello.py" else: script = args[0] # Set the path based on sys.path and the script directory path = sys.path[:] path[0] = os.path.dirname(script) path = addpath + path if debug > 1: print "path:" for item in path: print " ", repr(item) # Create the module finder and turn its crank mf = ModuleFinder(path, debug, exclude) for arg in args[1:]: if arg == '-m': domods = 1 continue if domods: if arg[-2:] == '.*': mf.import_hook(arg[:-2], None, ["*"]) else: mf.import_hook(arg) else: mf.load_file(arg) mf.run_script(script) mf.report() return mf # for -i debugging if __name__ == '__main__': try: mf = test() except KeyboardInterrupt: print "\n[interrupt]"
Upload File
Create Folder