Linux vps-61133.fhnet.fr 4.9.0-19-amd64 #1 SMP Debian 4.9.320-2 (2022-06-30) x86_64
Apache/2.4.25 (Debian)
Server IP : 93.113.207.21 & Your IP : 216.73.216.35
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
lib /
python2.7 /
Delete
Unzip
Name
Size
Permission
Date
Action
bsddb
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
compiler
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
config-x86_64-linux-gnu
[ DIR ]
drwxrwxrwx
2022-03-20 10:35
ctypes
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
curses
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
dist-packages
[ DIR ]
drwxrwxrwx
2022-03-20 10:38
distutils
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
email
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
encodings
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
ensurepip
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
hotshot
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
importlib
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
json
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
lib-dynload
[ DIR ]
drwxrwxrwx
2022-03-20 10:35
lib-tk
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
lib2to3
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
logging
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
multiprocessing
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
plat-x86_64-linux-gnu
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
pydoc_data
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
sqlite3
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
test
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
unittest
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
wsgiref
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
xml
[ DIR ]
drwxrwxrwx
2022-03-20 10:36
BaseHTTPServer.py
22.21
KB
-rw-r--r--
2022-02-06 21:16
BaseHTTPServer.pyc
21.17
KB
-rw-r--r--
2022-03-20 10:36
Bastion.py
5.61
KB
-rw-r--r--
2022-02-06 21:16
Bastion.pyc
6.47
KB
-rw-r--r--
2022-03-20 10:36
CGIHTTPServer.py
12.78
KB
-rw-r--r--
2022-02-06 21:16
CGIHTTPServer.pyc
10.73
KB
-rw-r--r--
2022-03-20 10:36
ConfigParser.py
27.1
KB
-rw-r--r--
2022-02-06 21:16
ConfigParser.pyc
24.51
KB
-rw-r--r--
2022-03-20 10:36
Cookie.py
25.92
KB
-rw-r--r--
2022-02-06 21:16
Cookie.pyc
22.05
KB
-rw-r--r--
2022-03-20 10:36
DocXMLRPCServer.py
10.52
KB
-rw-r--r--
2022-02-06 21:16
DocXMLRPCServer.pyc
9.92
KB
-rw-r--r--
2022-03-20 10:36
HTMLParser.py
16.73
KB
-rw-r--r--
2022-02-06 21:16
HTMLParser.pyc
13.34
KB
-rw-r--r--
2022-03-20 10:36
LICENSE.txt
12.47
KB
-rw-r--r--
2022-02-06 21:16
MimeWriter.py
6.33
KB
-rw-r--r--
2022-02-06 21:16
MimeWriter.pyc
7.17
KB
-rw-r--r--
2022-03-20 10:36
Queue.py
8.38
KB
-rw-r--r--
2022-02-06 21:16
Queue.pyc
9.15
KB
-rw-r--r--
2022-03-20 10:36
SimpleHTTPServer.py
7.81
KB
-rw-r--r--
2022-02-06 21:16
SimpleHTTPServer.pyc
7.8
KB
-rw-r--r--
2022-03-20 10:36
SimpleXMLRPCServer.py
25.21
KB
-rw-r--r--
2022-02-06 21:16
SimpleXMLRPCServer.pyc
22.26
KB
-rw-r--r--
2022-03-20 10:36
SocketServer.py
23.24
KB
-rw-r--r--
2022-02-06 21:16
SocketServer.pyc
23.39
KB
-rw-r--r--
2022-03-20 10:36
StringIO.py
10.41
KB
-rw-r--r--
2022-02-06 21:16
StringIO.pyc
11.17
KB
-rw-r--r--
2022-03-20 10:36
UserDict.py
6.89
KB
-rw-r--r--
2022-02-06 21:16
UserDict.pyc
9.4
KB
-rw-r--r--
2022-03-20 10:36
UserList.py
3.56
KB
-rw-r--r--
2022-02-06 21:16
UserList.pyc
6.36
KB
-rw-r--r--
2022-03-20 10:36
UserString.py
9.46
KB
-rwxr-xr-x
2022-02-06 21:16
UserString.pyc
14.38
KB
-rw-r--r--
2022-03-20 10:36
_LWPCookieJar.py
6.4
KB
-rw-r--r--
2022-02-06 21:16
_LWPCookieJar.pyc
5.29
KB
-rw-r--r--
2022-03-20 10:36
_MozillaCookieJar.py
5.66
KB
-rw-r--r--
2022-02-06 21:16
_MozillaCookieJar.pyc
4.35
KB
-rw-r--r--
2022-03-20 10:36
__future__.py
4.28
KB
-rw-r--r--
2022-02-06 21:16
__future__.pyc
4.11
KB
-rw-r--r--
2022-03-20 10:36
__phello__.foo.py
64
B
-rw-r--r--
2022-02-06 21:16
__phello__.foo.pyc
123
B
-rw-r--r--
2022-03-20 10:36
_abcoll.py
18.18
KB
-rw-r--r--
2022-02-06 21:16
_abcoll.pyc
24.88
KB
-rw-r--r--
2022-03-20 10:36
_osx_support.py
18.65
KB
-rw-r--r--
2022-02-06 21:16
_osx_support.pyc
11.45
KB
-rw-r--r--
2022-03-20 10:36
_pyio.py
67.96
KB
-rw-r--r--
2022-02-06 21:16
_pyio.pyc
62.82
KB
-rw-r--r--
2022-03-20 10:36
_strptime.py
20.24
KB
-rw-r--r--
2022-02-06 21:16
_strptime.pyc
14.77
KB
-rw-r--r--
2022-03-20 10:36
_sysconfigdata.py
126
B
-rw-r--r--
2022-02-06 21:16
_sysconfigdata.pyc
279
B
-rw-r--r--
2022-03-20 10:36
_threading_local.py
7.28
KB
-rw-r--r--
2022-02-06 21:16
_threading_local.pyc
6.4
KB
-rw-r--r--
2022-03-20 10:36
_weakrefset.py
5.77
KB
-rw-r--r--
2022-02-06 21:16
_weakrefset.pyc
9.36
KB
-rw-r--r--
2022-03-20 10:36
abc.py
6.98
KB
-rw-r--r--
2022-02-06 21:16
abc.pyc
5.98
KB
-rw-r--r--
2022-03-20 10:36
aifc.py
33.49
KB
-rw-r--r--
2022-02-06 21:16
aifc.pyc
29.5
KB
-rw-r--r--
2022-03-20 10:36
antigravity.py
60
B
-rw-r--r--
2022-02-06 21:16
antigravity.pyc
201
B
-rw-r--r--
2022-03-20 10:36
anydbm.py
2.6
KB
-rw-r--r--
2022-02-06 21:16
anydbm.pyc
2.73
KB
-rw-r--r--
2022-03-20 10:36
argparse.egg-info
217
B
-rw-r--r--
2022-02-06 21:16
argparse.py
87.04
KB
-rw-r--r--
2022-02-06 21:16
argparse.pyc
62.54
KB
-rw-r--r--
2022-03-20 10:36
ast.py
11.53
KB
-rw-r--r--
2022-02-06 21:16
ast.pyc
12.59
KB
-rw-r--r--
2022-03-20 10:36
asynchat.py
11.33
KB
-rw-r--r--
2022-02-06 21:16
asynchat.pyc
8.55
KB
-rw-r--r--
2022-03-20 10:36
asyncore.py
20.36
KB
-rw-r--r--
2022-02-06 21:16
asyncore.pyc
18.28
KB
-rw-r--r--
2022-03-20 10:36
atexit.py
1.67
KB
-rw-r--r--
2022-02-06 21:16
atexit.pyc
2.14
KB
-rw-r--r--
2022-03-20 10:36
audiodev.py
7.42
KB
-rw-r--r--
2022-02-06 21:16
audiodev.pyc
8.22
KB
-rw-r--r--
2022-03-20 10:36
base64.py
11.53
KB
-rwxr-xr-x
2022-02-06 21:16
base64.pyc
11
KB
-rw-r--r--
2022-03-20 10:36
bdb.py
21.21
KB
-rw-r--r--
2022-02-06 21:16
bdb.pyc
18.53
KB
-rw-r--r--
2022-03-20 10:36
binhex.py
14.35
KB
-rw-r--r--
2022-02-06 21:16
binhex.pyc
15
KB
-rw-r--r--
2022-03-20 10:36
bisect.py
2.53
KB
-rw-r--r--
2022-02-06 21:16
bisect.pyc
2.99
KB
-rw-r--r--
2022-03-20 10:36
cProfile.py
6.36
KB
-rwxr-xr-x
2022-02-06 21:16
cProfile.pyc
6.13
KB
-rw-r--r--
2022-03-20 10:36
calendar.py
22.84
KB
-rw-r--r--
2022-02-06 21:16
calendar.pyc
27.1
KB
-rw-r--r--
2022-03-20 10:36
cgi.py
34.35
KB
-rwxr-xr-x
2022-02-06 21:16
cgi.pyc
31.92
KB
-rw-r--r--
2022-03-20 10:36
cgitb.py
11.89
KB
-rw-r--r--
2022-02-06 21:16
cgitb.pyc
11.85
KB
-rw-r--r--
2022-03-20 10:36
chunk.py
5.29
KB
-rw-r--r--
2022-02-06 21:16
chunk.pyc
5.45
KB
-rw-r--r--
2022-03-20 10:36
cmd.py
14.67
KB
-rw-r--r--
2022-02-06 21:16
cmd.pyc
13.67
KB
-rw-r--r--
2022-03-20 10:36
code.py
9.95
KB
-rw-r--r--
2022-02-06 21:16
code.pyc
10.06
KB
-rw-r--r--
2022-03-20 10:36
codecs.py
35.25
KB
-rw-r--r--
2022-02-06 21:16
codecs.pyc
35.8
KB
-rw-r--r--
2022-03-20 10:36
codeop.py
5.86
KB
-rw-r--r--
2022-02-06 21:16
codeop.pyc
6.42
KB
-rw-r--r--
2022-03-20 10:36
collections.py
27.15
KB
-rw-r--r--
2022-02-06 21:16
collections.pyc
25.45
KB
-rw-r--r--
2022-03-20 10:36
colorsys.py
3.6
KB
-rw-r--r--
2022-02-06 21:16
colorsys.pyc
3.88
KB
-rw-r--r--
2022-03-20 10:36
commands.py
2.49
KB
-rw-r--r--
2022-02-06 21:16
commands.pyc
2.4
KB
-rw-r--r--
2022-03-20 10:36
compileall.py
7.58
KB
-rw-r--r--
2022-02-06 21:16
compileall.pyc
6.84
KB
-rw-r--r--
2022-03-20 10:36
contextlib.py
4.32
KB
-rw-r--r--
2022-02-06 21:16
contextlib.pyc
4.33
KB
-rw-r--r--
2022-03-20 10:36
cookielib.py
63.74
KB
-rw-r--r--
2022-02-06 21:16
cookielib.pyc
53.1
KB
-rw-r--r--
2022-03-20 10:36
copy.py
11.26
KB
-rw-r--r--
2022-02-06 21:16
copy.pyc
11.83
KB
-rw-r--r--
2022-03-20 10:36
copy_reg.py
6.64
KB
-rw-r--r--
2022-02-06 21:16
copy_reg.pyc
4.95
KB
-rw-r--r--
2022-03-20 10:36
csv.py
16.32
KB
-rw-r--r--
2022-02-06 21:16
csv.pyc
13.14
KB
-rw-r--r--
2022-03-20 10:36
dbhash.py
498
B
-rw-r--r--
2022-02-06 21:16
dbhash.pyc
714
B
-rw-r--r--
2022-03-20 10:36
decimal.py
216.73
KB
-rw-r--r--
2022-02-06 21:16
decimal.pyc
167.62
KB
-rw-r--r--
2022-03-20 10:36
difflib.py
80.4
KB
-rw-r--r--
2022-02-06 21:16
difflib.pyc
60.34
KB
-rw-r--r--
2022-03-20 10:36
dircache.py
1.1
KB
-rw-r--r--
2022-02-06 21:16
dircache.pyc
1.53
KB
-rw-r--r--
2022-03-20 10:36
dis.py
6.35
KB
-rw-r--r--
2022-02-06 21:16
dis.pyc
6.07
KB
-rw-r--r--
2022-03-20 10:36
doctest.py
102.75
KB
-rw-r--r--
2022-02-06 21:16
doctest.pyc
81.49
KB
-rw-r--r--
2022-03-20 10:36
dumbdbm.py
8.93
KB
-rw-r--r--
2022-02-06 21:16
dumbdbm.pyc
6.55
KB
-rw-r--r--
2022-03-20 10:36
dummy_thread.py
4.31
KB
-rw-r--r--
2022-02-06 21:16
dummy_thread.pyc
5.24
KB
-rw-r--r--
2022-03-20 10:36
dummy_threading.py
2.74
KB
-rw-r--r--
2022-02-06 21:16
dummy_threading.pyc
1.25
KB
-rw-r--r--
2022-03-20 10:36
filecmp.py
9.36
KB
-rw-r--r--
2022-02-06 21:16
filecmp.pyc
9.36
KB
-rw-r--r--
2022-03-20 10:36
fileinput.py
13.42
KB
-rw-r--r--
2022-02-06 21:16
fileinput.pyc
14.1
KB
-rw-r--r--
2022-03-20 10:36
fnmatch.py
3.24
KB
-rw-r--r--
2022-02-06 21:16
fnmatch.pyc
3.52
KB
-rw-r--r--
2022-03-20 10:36
formatter.py
14.56
KB
-rw-r--r--
2022-02-06 21:16
formatter.pyc
18.58
KB
-rw-r--r--
2022-03-20 10:36
fpformat.py
4.59
KB
-rw-r--r--
2022-02-06 21:16
fpformat.pyc
4.55
KB
-rw-r--r--
2022-03-20 10:36
fractions.py
21.87
KB
-rw-r--r--
2022-02-06 21:16
fractions.pyc
19.17
KB
-rw-r--r--
2022-03-20 10:36
ftplib.py
37.23
KB
-rw-r--r--
2022-02-06 21:16
ftplib.pyc
33.81
KB
-rw-r--r--
2022-03-20 10:36
functools.py
4.37
KB
-rw-r--r--
2022-02-06 21:16
functools.pyc
5.86
KB
-rw-r--r--
2022-03-20 10:36
genericpath.py
3.13
KB
-rw-r--r--
2022-02-06 21:16
genericpath.pyc
3.41
KB
-rw-r--r--
2022-03-20 10:36
getopt.py
7.15
KB
-rw-r--r--
2022-02-06 21:16
getopt.pyc
6.48
KB
-rw-r--r--
2022-03-20 10:36
getpass.py
5.43
KB
-rw-r--r--
2022-02-06 21:16
getpass.pyc
4.62
KB
-rw-r--r--
2022-03-20 10:36
gettext.py
22.06
KB
-rw-r--r--
2022-02-06 21:16
gettext.pyc
17.45
KB
-rw-r--r--
2022-03-20 10:36
glob.py
3.04
KB
-rw-r--r--
2022-02-06 21:16
glob.pyc
2.86
KB
-rw-r--r--
2022-03-20 10:36
gzip.py
18.58
KB
-rw-r--r--
2022-02-06 21:16
gzip.pyc
14.78
KB
-rw-r--r--
2022-03-20 10:36
hashlib.py
7.66
KB
-rw-r--r--
2022-02-06 21:16
hashlib.pyc
6.73
KB
-rw-r--r--
2022-03-20 10:36
heapq.py
17.87
KB
-rw-r--r--
2022-02-06 21:16
heapq.pyc
14.19
KB
-rw-r--r--
2022-03-20 10:36
hmac.py
4.48
KB
-rw-r--r--
2022-02-06 21:16
hmac.pyc
4.42
KB
-rw-r--r--
2022-03-20 10:36
htmlentitydefs.py
17.63
KB
-rw-r--r--
2022-02-06 21:16
htmlentitydefs.pyc
6.22
KB
-rw-r--r--
2022-03-20 10:36
htmllib.py
12.57
KB
-rw-r--r--
2022-02-06 21:16
htmllib.pyc
19.66
KB
-rw-r--r--
2022-03-20 10:36
httplib.py
50.26
KB
-rw-r--r--
2022-02-06 21:16
httplib.pyc
35.86
KB
-rw-r--r--
2022-03-20 10:36
ihooks.py
18.54
KB
-rw-r--r--
2022-02-06 21:16
ihooks.pyc
20.74
KB
-rw-r--r--
2022-03-20 10:36
imaplib.py
47.28
KB
-rw-r--r--
2022-02-06 21:16
imaplib.pyc
44.07
KB
-rw-r--r--
2022-03-20 10:36
imghdr.py
3.46
KB
-rw-r--r--
2022-02-06 21:16
imghdr.pyc
4.69
KB
-rw-r--r--
2022-03-20 10:36
imputil.py
25.16
KB
-rw-r--r--
2022-02-06 21:16
imputil.pyc
15.18
KB
-rw-r--r--
2022-03-20 10:36
inspect.py
41.62
KB
-rw-r--r--
2022-02-06 21:16
inspect.pyc
38.97
KB
-rw-r--r--
2022-03-20 10:36
io.py
3.24
KB
-rw-r--r--
2022-02-06 21:16
io.pyc
3.5
KB
-rw-r--r--
2022-03-20 10:36
keyword.py
1.95
KB
-rwxr-xr-x
2022-02-06 21:16
keyword.pyc
2.05
KB
-rw-r--r--
2022-03-20 10:36
linecache.py
3.93
KB
-rw-r--r--
2022-02-06 21:16
linecache.pyc
3.18
KB
-rw-r--r--
2022-03-20 10:36
locale.py
97.19
KB
-rw-r--r--
2022-02-06 21:16
locale.pyc
53.69
KB
-rw-r--r--
2022-03-20 10:36
macpath.py
6.14
KB
-rw-r--r--
2022-02-06 21:16
macpath.pyc
7.46
KB
-rw-r--r--
2022-03-20 10:36
macurl2path.py
2.67
KB
-rw-r--r--
2022-02-06 21:16
macurl2path.pyc
2.18
KB
-rw-r--r--
2022-03-20 10:36
mailbox.py
79.34
KB
-rw-r--r--
2022-02-06 21:16
mailbox.pyc
74.49
KB
-rw-r--r--
2022-03-20 10:36
mailcap.py
7.25
KB
-rw-r--r--
2022-02-06 21:16
mailcap.pyc
6.89
KB
-rw-r--r--
2022-03-20 10:36
markupbase.py
14.3
KB
-rw-r--r--
2022-02-06 21:16
markupbase.pyc
9.02
KB
-rw-r--r--
2022-03-20 10:36
md5.py
358
B
-rw-r--r--
2022-02-06 21:16
md5.pyc
376
B
-rw-r--r--
2022-03-20 10:36
mhlib.py
32.65
KB
-rw-r--r--
2022-02-06 21:16
mhlib.pyc
32.83
KB
-rw-r--r--
2022-03-20 10:36
mimetools.py
7
KB
-rw-r--r--
2022-02-06 21:16
mimetools.pyc
7.97
KB
-rw-r--r--
2022-03-20 10:36
mimetypes.py
20.45
KB
-rw-r--r--
2022-02-06 21:16
mimetypes.pyc
17.96
KB
-rw-r--r--
2022-03-20 10:36
mimify.py
14.67
KB
-rwxr-xr-x
2022-02-06 21:16
mimify.pyc
11.69
KB
-rw-r--r--
2022-03-20 10:36
modulefinder.py
23.89
KB
-rw-r--r--
2022-02-06 21:16
modulefinder.pyc
18.61
KB
-rw-r--r--
2022-03-20 10:36
multifile.py
4.71
KB
-rw-r--r--
2022-02-06 21:16
multifile.pyc
5.26
KB
-rw-r--r--
2022-03-20 10:36
mutex.py
1.83
KB
-rw-r--r--
2022-02-06 21:16
mutex.pyc
2.44
KB
-rw-r--r--
2022-03-20 10:36
netrc.py
5.73
KB
-rw-r--r--
2022-02-06 21:16
netrc.pyc
4.54
KB
-rw-r--r--
2022-03-20 10:36
new.py
610
B
-rw-r--r--
2022-02-06 21:16
new.pyc
860
B
-rw-r--r--
2022-03-20 10:36
nntplib.py
20.97
KB
-rw-r--r--
2022-02-06 21:16
nntplib.pyc
20.46
KB
-rw-r--r--
2022-03-20 10:36
ntpath.py
18.97
KB
-rw-r--r--
2022-02-06 21:16
ntpath.pyc
12.78
KB
-rw-r--r--
2022-03-20 10:36
nturl2path.py
2.36
KB
-rw-r--r--
2022-02-06 21:16
nturl2path.pyc
1.77
KB
-rw-r--r--
2022-03-20 10:36
numbers.py
10.08
KB
-rw-r--r--
2022-02-06 21:16
numbers.pyc
13.56
KB
-rw-r--r--
2022-03-20 10:36
opcode.py
5.35
KB
-rw-r--r--
2022-02-06 21:16
opcode.pyc
5.99
KB
-rw-r--r--
2022-03-20 10:36
optparse.py
59.77
KB
-rw-r--r--
2022-02-06 21:16
optparse.pyc
52.36
KB
-rw-r--r--
2022-03-20 10:36
os.py
25.3
KB
-rw-r--r--
2022-02-06 21:16
os.pyc
24.98
KB
-rw-r--r--
2022-03-20 10:36
os2emxpath.py
4.53
KB
-rw-r--r--
2022-02-06 21:16
os2emxpath.pyc
4.4
KB
-rw-r--r--
2022-03-20 10:36
pdb.doc
7.73
KB
-rw-r--r--
2022-02-06 21:16
pdb.py
45.02
KB
-rwxr-xr-x
2022-02-06 21:16
pdb.pyc
42.42
KB
-rw-r--r--
2022-03-20 10:36
pickle.py
44.42
KB
-rw-r--r--
2022-02-06 21:16
pickle.pyc
37.45
KB
-rw-r--r--
2022-03-20 10:36
pickletools.py
72.79
KB
-rw-r--r--
2022-02-06 21:16
pickletools.pyc
55.64
KB
-rw-r--r--
2022-03-20 10:36
pipes.py
9.36
KB
-rw-r--r--
2022-02-06 21:16
pipes.pyc
9.06
KB
-rw-r--r--
2022-03-20 10:36
pkgutil.py
19.87
KB
-rw-r--r--
2022-02-06 21:16
pkgutil.pyc
18.42
KB
-rw-r--r--
2022-03-20 10:36
platform.py
51.38
KB
-rwxr-xr-x
2022-02-06 21:16
platform.pyc
36.84
KB
-rw-r--r--
2022-03-20 10:36
plistlib.py
14.83
KB
-rw-r--r--
2022-02-06 21:16
plistlib.pyc
18.67
KB
-rw-r--r--
2022-03-20 10:36
popen2.py
8.22
KB
-rw-r--r--
2022-02-06 21:16
popen2.pyc
8.78
KB
-rw-r--r--
2022-03-20 10:36
poplib.py
12.52
KB
-rw-r--r--
2022-02-06 21:16
poplib.pyc
12.97
KB
-rw-r--r--
2022-03-20 10:36
posixfile.py
7.82
KB
-rw-r--r--
2022-02-06 21:16
posixfile.pyc
7.45
KB
-rw-r--r--
2022-03-20 10:36
posixpath.py
13.61
KB
-rw-r--r--
2022-02-06 21:16
posixpath.pyc
11.12
KB
-rw-r--r--
2022-03-20 10:36
pprint.py
11.5
KB
-rw-r--r--
2022-02-06 21:16
pprint.pyc
9.92
KB
-rw-r--r--
2022-03-20 10:36
profile.py
22.25
KB
-rwxr-xr-x
2022-02-06 21:16
profile.pyc
15.99
KB
-rw-r--r--
2022-03-20 10:36
pstats.py
26.09
KB
-rw-r--r--
2022-02-06 21:16
pstats.pyc
24.31
KB
-rw-r--r--
2022-03-20 10:36
pty.py
4.94
KB
-rw-r--r--
2022-02-06 21:16
pty.pyc
4.83
KB
-rw-r--r--
2022-03-20 10:36
py_compile.py
6.14
KB
-rw-r--r--
2022-02-06 21:16
py_compile.pyc
6.46
KB
-rw-r--r--
2022-03-20 10:36
pyclbr.py
13.07
KB
-rw-r--r--
2022-02-06 21:16
pyclbr.pyc
9.4
KB
-rw-r--r--
2022-03-20 10:36
pydoc.py
93.56
KB
-rwxr-xr-x
2022-02-06 21:16
pydoc.pyc
89.91
KB
-rw-r--r--
2022-03-20 10:36
quopri.py
6.8
KB
-rwxr-xr-x
2022-02-06 21:16
quopri.pyc
6.4
KB
-rw-r--r--
2022-03-20 10:36
random.py
31.57
KB
-rw-r--r--
2022-02-06 21:16
random.pyc
24.89
KB
-rw-r--r--
2022-03-20 10:36
re.py
13.11
KB
-rw-r--r--
2022-02-06 21:16
re.pyc
13.06
KB
-rw-r--r--
2022-03-20 10:36
repr.py
4.2
KB
-rw-r--r--
2022-02-06 21:16
repr.pyc
5.23
KB
-rw-r--r--
2022-03-20 10:36
rexec.py
19.68
KB
-rw-r--r--
2022-02-06 21:16
rexec.pyc
23.13
KB
-rw-r--r--
2022-03-20 10:36
rfc822.py
32.76
KB
-rw-r--r--
2022-02-06 21:16
rfc822.pyc
30.95
KB
-rw-r--r--
2022-03-20 10:36
rlcompleter.py
5.85
KB
-rw-r--r--
2022-02-06 21:16
rlcompleter.pyc
5.92
KB
-rw-r--r--
2022-03-20 10:36
robotparser.py
7.41
KB
-rw-r--r--
2022-02-06 21:16
robotparser.pyc
7.73
KB
-rw-r--r--
2022-03-20 10:36
runpy.py
10.82
KB
-rw-r--r--
2022-02-06 21:16
runpy.pyc
8.56
KB
-rw-r--r--
2022-03-20 10:36
sched.py
4.97
KB
-rw-r--r--
2022-02-06 21:16
sched.pyc
4.86
KB
-rw-r--r--
2022-03-20 10:36
sets.py
18.6
KB
-rw-r--r--
2022-02-06 21:16
sets.pyc
16.39
KB
-rw-r--r--
2022-03-20 10:36
sgmllib.py
17.46
KB
-rw-r--r--
2022-02-06 21:16
sgmllib.pyc
14.98
KB
-rw-r--r--
2022-03-20 10:36
sha.py
393
B
-rw-r--r--
2022-02-06 21:16
sha.pyc
419
B
-rw-r--r--
2022-03-20 10:36
shelve.py
7.99
KB
-rw-r--r--
2022-02-06 21:16
shelve.pyc
9.96
KB
-rw-r--r--
2022-03-20 10:36
shlex.py
10.9
KB
-rw-r--r--
2022-02-06 21:16
shlex.pyc
7.36
KB
-rw-r--r--
2022-03-20 10:36
shutil.py
18.63
KB
-rw-r--r--
2022-02-06 21:16
shutil.pyc
18.12
KB
-rw-r--r--
2022-03-20 10:36
site.py
19.48
KB
-rw-r--r--
2022-02-06 21:16
site.pyc
19.08
KB
-rw-r--r--
2022-03-20 10:36
sitecustomize.py
155
B
-rw-r--r--
2017-11-24 18:33
sitecustomize.pyc
232
B
-rw-r--r--
2022-03-20 10:36
smtpd.py
18.11
KB
-rwxr-xr-x
2022-02-06 21:16
smtpd.pyc
15.45
KB
-rw-r--r--
2022-03-20 10:36
smtplib.py
31.35
KB
-rwxr-xr-x
2022-02-06 21:16
smtplib.pyc
29.47
KB
-rw-r--r--
2022-03-20 10:36
sndhdr.py
5.83
KB
-rw-r--r--
2022-02-06 21:16
sndhdr.pyc
7.16
KB
-rw-r--r--
2022-03-20 10:36
socket.py
20.13
KB
-rw-r--r--
2022-02-06 21:16
socket.pyc
15.71
KB
-rw-r--r--
2022-03-20 10:36
sre.py
384
B
-rw-r--r--
2022-02-06 21:16
sre.pyc
517
B
-rw-r--r--
2022-03-20 10:36
sre_compile.py
19.35
KB
-rw-r--r--
2022-02-06 21:16
sre_compile.pyc
12.24
KB
-rw-r--r--
2022-03-20 10:36
sre_constants.py
7.03
KB
-rw-r--r--
2022-02-06 21:16
sre_constants.pyc
6.04
KB
-rw-r--r--
2022-03-20 10:36
sre_parse.py
28.23
KB
-rw-r--r--
2022-02-06 21:16
sre_parse.pyc
19.48
KB
-rw-r--r--
2022-03-20 10:36
ssl.py
36.92
KB
-rw-r--r--
2022-02-06 21:16
ssl.pyc
31.47
KB
-rw-r--r--
2022-03-20 10:36
stat.py
1.8
KB
-rw-r--r--
2022-02-06 21:16
stat.pyc
2.67
KB
-rw-r--r--
2022-03-20 10:36
statvfs.py
898
B
-rw-r--r--
2022-02-06 21:16
statvfs.pyc
618
B
-rw-r--r--
2022-03-20 10:36
string.py
21.04
KB
-rw-r--r--
2022-02-06 21:16
string.pyc
19.88
KB
-rw-r--r--
2022-03-20 10:36
stringold.py
12.16
KB
-rw-r--r--
2022-02-06 21:16
stringold.pyc
12.2
KB
-rw-r--r--
2022-03-20 10:36
stringprep.py
13.21
KB
-rw-r--r--
2022-02-06 21:16
stringprep.pyc
14.11
KB
-rw-r--r--
2022-03-20 10:36
struct.py
82
B
-rw-r--r--
2022-02-06 21:16
struct.pyc
237
B
-rw-r--r--
2022-03-20 10:36
subprocess.py
48.26
KB
-rw-r--r--
2022-02-06 21:16
subprocess.pyc
30.8
KB
-rw-r--r--
2022-03-20 10:36
sunau.py
16.82
KB
-rw-r--r--
2022-02-06 21:16
sunau.pyc
17.87
KB
-rw-r--r--
2022-03-20 10:36
sunaudio.py
1.37
KB
-rw-r--r--
2022-02-06 21:16
sunaudio.pyc
1.93
KB
-rw-r--r--
2022-03-20 10:36
symbol.py
2.01
KB
-rwxr-xr-x
2022-02-06 21:16
symbol.pyc
2.95
KB
-rw-r--r--
2022-03-20 10:36
symtable.py
7.26
KB
-rw-r--r--
2022-02-06 21:16
symtable.pyc
11.41
KB
-rw-r--r--
2022-03-20 10:36
sysconfig.py
24.61
KB
-rw-r--r--
2022-02-06 21:16
sysconfig.pyc
18.19
KB
-rw-r--r--
2022-03-20 10:36
tabnanny.py
11.07
KB
-rwxr-xr-x
2022-02-06 21:16
tabnanny.pyc
8.01
KB
-rw-r--r--
2022-03-20 10:36
tarfile.py
88.53
KB
-rw-r--r--
2022-02-06 21:16
tarfile.pyc
74.07
KB
-rw-r--r--
2022-03-20 10:36
telnetlib.py
26.41
KB
-rw-r--r--
2022-02-06 21:16
telnetlib.pyc
22.54
KB
-rw-r--r--
2022-03-20 10:36
tempfile.py
19.09
KB
-rw-r--r--
2022-02-06 21:16
tempfile.pyc
19.76
KB
-rw-r--r--
2022-03-20 10:36
textwrap.py
16.81
KB
-rw-r--r--
2022-02-06 21:16
textwrap.pyc
11.72
KB
-rw-r--r--
2022-03-20 10:36
this.py
1002
B
-rw-r--r--
2022-02-06 21:16
this.pyc
1.19
KB
-rw-r--r--
2022-03-20 10:36
threading.py
46.03
KB
-rw-r--r--
2022-02-06 21:16
threading.pyc
41.44
KB
-rw-r--r--
2022-03-20 10:36
timeit.py
12.49
KB
-rwxr-xr-x
2022-02-06 21:16
timeit.pyc
11.87
KB
-rw-r--r--
2022-03-20 10:36
toaiff.py
3.07
KB
-rw-r--r--
2022-02-06 21:16
toaiff.pyc
3.03
KB
-rw-r--r--
2022-03-20 10:36
token.py
2.85
KB
-rw-r--r--
2022-02-06 21:16
token.pyc
3.72
KB
-rw-r--r--
2022-03-20 10:36
tokenize.py
17.07
KB
-rw-r--r--
2022-02-06 21:16
tokenize.pyc
14.13
KB
-rw-r--r--
2022-03-20 10:36
trace.py
29.19
KB
-rwxr-xr-x
2022-02-06 21:16
trace.pyc
22.19
KB
-rw-r--r--
2022-03-20 10:36
traceback.py
11.02
KB
-rw-r--r--
2022-02-06 21:16
traceback.pyc
11.37
KB
-rw-r--r--
2022-03-20 10:36
tty.py
879
B
-rw-r--r--
2022-02-06 21:16
tty.pyc
1.28
KB
-rw-r--r--
2022-03-20 10:36
types.py
2.04
KB
-rw-r--r--
2022-02-06 21:16
types.pyc
2.65
KB
-rw-r--r--
2022-03-20 10:36
urllib.py
58.68
KB
-rw-r--r--
2022-02-06 21:16
urllib.pyc
49.75
KB
-rw-r--r--
2022-03-20 10:36
urllib2.py
51.28
KB
-rw-r--r--
2022-02-06 21:16
urllib2.pyc
45.92
KB
-rw-r--r--
2022-03-20 10:36
urlparse.py
16.06
KB
-rw-r--r--
2022-02-06 21:16
urlparse.pyc
15.07
KB
-rw-r--r--
2022-03-20 10:36
user.py
1.59
KB
-rw-r--r--
2022-02-06 21:16
user.pyc
1.68
KB
-rw-r--r--
2022-03-20 10:36
uu.py
6.4
KB
-rwxr-xr-x
2022-02-06 21:16
uu.pyc
4.2
KB
-rw-r--r--
2022-03-20 10:36
uuid.py
22.08
KB
-rw-r--r--
2022-02-06 21:16
uuid.pyc
21.95
KB
-rw-r--r--
2022-03-20 10:36
warnings.py
14.4
KB
-rw-r--r--
2022-02-06 21:16
warnings.pyc
13.12
KB
-rw-r--r--
2022-03-20 10:36
wave.py
18.15
KB
-rw-r--r--
2022-02-06 21:16
wave.pyc
19.44
KB
-rw-r--r--
2022-03-20 10:36
weakref.py
13.28
KB
-rw-r--r--
2022-02-06 21:16
weakref.pyc
15.37
KB
-rw-r--r--
2022-03-20 10:36
webbrowser.py
22.25
KB
-rwxr-xr-x
2022-02-06 21:16
webbrowser.pyc
19.26
KB
-rw-r--r--
2022-03-20 10:36
whichdb.py
3.3
KB
-rw-r--r--
2022-02-06 21:16
whichdb.pyc
2.18
KB
-rw-r--r--
2022-03-20 10:36
wsgiref.egg-info
187
B
-rw-r--r--
2022-02-06 21:16
xdrlib.py
5.93
KB
-rw-r--r--
2022-02-06 21:16
xdrlib.pyc
9.59
KB
-rw-r--r--
2022-03-20 10:36
xmllib.py
34.05
KB
-rw-r--r--
2022-02-06 21:16
xmllib.pyc
26.11
KB
-rw-r--r--
2022-03-20 10:36
xmlrpclib.py
50.91
KB
-rw-r--r--
2022-02-06 21:16
xmlrpclib.pyc
42.8
KB
-rw-r--r--
2022-03-20 10:36
zipfile.py
57.64
KB
-rw-r--r--
2022-02-06 21:16
zipfile.pyc
40.52
KB
-rw-r--r--
2022-03-20 10:36
Save
Rename
#! /usr/bin/python2.7 # portions copyright 2001, Autonomous Zones Industries, Inc., all rights... # err... reserved and offered to the public under the terms of the # Python 2.2 license. # Author: Zooko O'Whielacronx # http://zooko.com/ # mailto:zooko@zooko.com # # Copyright 2000, Mojam Media, Inc., all rights reserved. # Author: Skip Montanaro # # Copyright 1999, Bioreason, Inc., all rights reserved. # Author: Andrew Dalke # # Copyright 1995-1997, Automatrix, Inc., all rights reserved. # Author: Skip Montanaro # # Copyright 1991-1995, Stichting Mathematisch Centrum, all rights reserved. # # # Permission to use, copy, modify, and distribute this Python software and # its associated documentation for any purpose without fee is hereby # granted, provided that the above copyright notice appears in all copies, # and that both that copyright notice and this permission notice appear in # supporting documentation, and that the name of neither Automatrix, # Bioreason or Mojam Media be used in advertising or publicity pertaining to # distribution of the software without specific, written prior permission. # """program/module to trace Python program or function execution Sample use, command line: trace.py -c -f counts --ignore-dir '$prefix' spam.py eggs trace.py -t --ignore-dir '$prefix' spam.py eggs trace.py --trackcalls spam.py eggs Sample use, programmatically import sys # create a Trace object, telling it what to ignore, and whether to # do tracing or line-counting or both. tracer = trace.Trace(ignoredirs=[sys.prefix, sys.exec_prefix,], trace=0, count=1) # run the new command using the given tracer tracer.run('main()') # make a report, placing output in /tmp r = tracer.results() r.write_results(show_missing=True, coverdir="/tmp") """ import linecache import os import re import sys import time import token import tokenize import inspect import gc import dis try: import cPickle pickle = cPickle except ImportError: import pickle try: import threading except ImportError: _settrace = sys.settrace def _unsettrace(): sys.settrace(None) else: def _settrace(func): threading.settrace(func) sys.settrace(func) def _unsettrace(): sys.settrace(None) threading.settrace(None) def usage(outfile): outfile.write("""Usage: %s [OPTIONS] <file> [ARGS] Meta-options: --help Display this help then exit. --version Output version information then exit. Otherwise, exactly one of the following three options must be given: -t, --trace Print each line to sys.stdout before it is executed. -c, --count Count the number of times each line is executed and write the counts to <module>.cover for each module executed, in the module's directory. See also `--coverdir', `--file', `--no-report' below. -l, --listfuncs Keep track of which functions are executed at least once and write the results to sys.stdout after the program exits. -T, --trackcalls Keep track of caller/called pairs and write the results to sys.stdout after the program exits. -r, --report Generate a report from a counts file; do not execute any code. `--file' must specify the results file to read, which must have been created in a previous run with `--count --file=FILE'. Modifiers: -f, --file=<file> File to accumulate counts over several runs. -R, --no-report Do not generate the coverage report files. Useful if you want to accumulate over several runs. -C, --coverdir=<dir> Directory where the report files. The coverage report for <package>.<module> is written to file <dir>/<package>/<module>.cover. -m, --missing Annotate executable lines that were not executed with '>>>>>> '. -s, --summary Write a brief summary on stdout for each file. (Can only be used with --count or --report.) -g, --timing Prefix each line with the time since the program started. Only used while tracing. Filters, may be repeated multiple times: --ignore-module=<mod> Ignore the given module(s) and its submodules (if it is a package). Accepts comma separated list of module names --ignore-dir=<dir> Ignore files in the given directory (multiple directories can be joined by os.pathsep). """ % sys.argv[0]) PRAGMA_NOCOVER = "#pragma NO COVER" # Simple rx to find lines with no code. rx_blank = re.compile(r'^\s*(#.*)?$') class Ignore: def __init__(self, modules = None, dirs = None): self._mods = modules or [] self._dirs = dirs or [] self._dirs = map(os.path.normpath, self._dirs) self._ignore = { '<string>': 1 } def names(self, filename, modulename): if modulename in self._ignore: return self._ignore[modulename] # haven't seen this one before, so see if the module name is # on the ignore list. Need to take some care since ignoring # "cmp" musn't mean ignoring "cmpcache" but ignoring # "Spam" must also mean ignoring "Spam.Eggs". for mod in self._mods: if mod == modulename: # Identical names, so ignore self._ignore[modulename] = 1 return 1 # check if the module is a proper submodule of something on # the ignore list n = len(mod) # (will not overflow since if the first n characters are the # same and the name has not already occurred, then the size # of "name" is greater than that of "mod") if mod == modulename[:n] and modulename[n] == '.': self._ignore[modulename] = 1 return 1 # Now check that __file__ isn't in one of the directories if filename is None: # must be a built-in, so we must ignore self._ignore[modulename] = 1 return 1 # Ignore a file when it contains one of the ignorable paths for d in self._dirs: # The '+ os.sep' is to ensure that d is a parent directory, # as compared to cases like: # d = "/usr/local" # filename = "/usr/local.py" # or # d = "/usr/local.py" # filename = "/usr/local.py" if filename.startswith(d + os.sep): self._ignore[modulename] = 1 return 1 # Tried the different ways, so we don't ignore this module self._ignore[modulename] = 0 return 0 def modname(path): """Return a plausible module name for the patch.""" base = os.path.basename(path) filename, ext = os.path.splitext(base) return filename def fullmodname(path): """Return a plausible module name for the path.""" # If the file 'path' is part of a package, then the filename isn't # enough to uniquely identify it. Try to do the right thing by # looking in sys.path for the longest matching prefix. We'll # assume that the rest is the package name. comparepath = os.path.normcase(path) longest = "" for dir in sys.path: dir = os.path.normcase(dir) if comparepath.startswith(dir) and comparepath[len(dir)] == os.sep: if len(dir) > len(longest): longest = dir if longest: base = path[len(longest) + 1:] else: base = path # the drive letter is never part of the module name drive, base = os.path.splitdrive(base) base = base.replace(os.sep, ".") if os.altsep: base = base.replace(os.altsep, ".") filename, ext = os.path.splitext(base) return filename.lstrip(".") class CoverageResults: def __init__(self, counts=None, calledfuncs=None, infile=None, callers=None, outfile=None): self.counts = counts if self.counts is None: self.counts = {} self.counter = self.counts.copy() # map (filename, lineno) to count self.calledfuncs = calledfuncs if self.calledfuncs is None: self.calledfuncs = {} self.calledfuncs = self.calledfuncs.copy() self.callers = callers if self.callers is None: self.callers = {} self.callers = self.callers.copy() self.infile = infile self.outfile = outfile if self.infile: # Try to merge existing counts file. try: counts, calledfuncs, callers = \ pickle.load(open(self.infile, 'rb')) self.update(self.__class__(counts, calledfuncs, callers)) except (IOError, EOFError, ValueError), err: print >> sys.stderr, ("Skipping counts file %r: %s" % (self.infile, err)) def update(self, other): """Merge in the data from another CoverageResults""" counts = self.counts calledfuncs = self.calledfuncs callers = self.callers other_counts = other.counts other_calledfuncs = other.calledfuncs other_callers = other.callers for key in other_counts.keys(): counts[key] = counts.get(key, 0) + other_counts[key] for key in other_calledfuncs.keys(): calledfuncs[key] = 1 for key in other_callers.keys(): callers[key] = 1 def write_results(self, show_missing=True, summary=False, coverdir=None): """ @param coverdir """ if self.calledfuncs: print print "functions called:" calls = self.calledfuncs.keys() calls.sort() for filename, modulename, funcname in calls: print ("filename: %s, modulename: %s, funcname: %s" % (filename, modulename, funcname)) if self.callers: print print "calling relationships:" calls = self.callers.keys() calls.sort() lastfile = lastcfile = "" for ((pfile, pmod, pfunc), (cfile, cmod, cfunc)) in calls: if pfile != lastfile: print print "***", pfile, "***" lastfile = pfile lastcfile = "" if cfile != pfile and lastcfile != cfile: print " -->", cfile lastcfile = cfile print " %s.%s -> %s.%s" % (pmod, pfunc, cmod, cfunc) # turn the counts data ("(filename, lineno) = count") into something # accessible on a per-file basis per_file = {} for filename, lineno in self.counts.keys(): lines_hit = per_file[filename] = per_file.get(filename, {}) lines_hit[lineno] = self.counts[(filename, lineno)] # accumulate summary info, if needed sums = {} for filename, count in per_file.iteritems(): # skip some "files" we don't care about... if filename == "<string>": continue if filename.startswith("<doctest "): continue if filename.endswith((".pyc", ".pyo")): filename = filename[:-1] if coverdir is None: dir = os.path.dirname(os.path.abspath(filename)) modulename = modname(filename) else: dir = coverdir if not os.path.exists(dir): os.makedirs(dir) modulename = fullmodname(filename) # If desired, get a list of the line numbers which represent # executable content (returned as a dict for better lookup speed) if show_missing: lnotab = find_executable_linenos(filename) else: lnotab = {} source = linecache.getlines(filename) coverpath = os.path.join(dir, modulename + ".cover") n_hits, n_lines = self.write_results_file(coverpath, source, lnotab, count) if summary and n_lines: percent = 100 * n_hits // n_lines sums[modulename] = n_lines, percent, modulename, filename if summary and sums: mods = sums.keys() mods.sort() print "lines cov% module (path)" for m in mods: n_lines, percent, modulename, filename = sums[m] print "%5d %3d%% %s (%s)" % sums[m] if self.outfile: # try and store counts and module info into self.outfile try: pickle.dump((self.counts, self.calledfuncs, self.callers), open(self.outfile, 'wb'), 1) except IOError, err: print >> sys.stderr, "Can't save counts files because %s" % err def write_results_file(self, path, lines, lnotab, lines_hit): """Return a coverage results file in path.""" try: outfile = open(path, "w") except IOError, err: print >> sys.stderr, ("trace: Could not open %r for writing: %s" "- skipping" % (path, err)) return 0, 0 n_lines = 0 n_hits = 0 for i, line in enumerate(lines): lineno = i + 1 # do the blank/comment match to try to mark more lines # (help the reader find stuff that hasn't been covered) if lineno in lines_hit: outfile.write("%5d: " % lines_hit[lineno]) n_hits += 1 n_lines += 1 elif rx_blank.match(line): outfile.write(" ") else: # lines preceded by no marks weren't hit # Highlight them if so indicated, unless the line contains # #pragma: NO COVER if lineno in lnotab and not PRAGMA_NOCOVER in lines[i]: outfile.write(">>>>>> ") n_lines += 1 else: outfile.write(" ") outfile.write(lines[i].expandtabs(8)) outfile.close() return n_hits, n_lines def find_lines_from_code(code, strs): """Return dict where keys are lines in the line number table.""" linenos = {} for _, lineno in dis.findlinestarts(code): if lineno not in strs: linenos[lineno] = 1 return linenos def find_lines(code, strs): """Return lineno dict for all code objects reachable from code.""" # get all of the lineno information from the code of this scope level linenos = find_lines_from_code(code, strs) # and check the constants for references to other code objects for c in code.co_consts: if inspect.iscode(c): # find another code object, so recurse into it linenos.update(find_lines(c, strs)) return linenos def find_strings(filename): """Return a dict of possible docstring positions. The dict maps line numbers to strings. There is an entry for line that contains only a string or a part of a triple-quoted string. """ d = {} # If the first token is a string, then it's the module docstring. # Add this special case so that the test in the loop passes. prev_ttype = token.INDENT f = open(filename) for ttype, tstr, start, end, line in tokenize.generate_tokens(f.readline): if ttype == token.STRING: if prev_ttype == token.INDENT: sline, scol = start eline, ecol = end for i in range(sline, eline + 1): d[i] = 1 prev_ttype = ttype f.close() return d def find_executable_linenos(filename): """Return dict where keys are line numbers in the line number table.""" try: prog = open(filename, "rU").read() except IOError, err: print >> sys.stderr, ("Not printing coverage data for %r: %s" % (filename, err)) return {} code = compile(prog, filename, "exec") strs = find_strings(filename) return find_lines(code, strs) class Trace: def __init__(self, count=1, trace=1, countfuncs=0, countcallers=0, ignoremods=(), ignoredirs=(), infile=None, outfile=None, timing=False): """ @param count true iff it should count number of times each line is executed @param trace true iff it should print out each line that is being counted @param countfuncs true iff it should just output a list of (filename, modulename, funcname,) for functions that were called at least once; This overrides `count' and `trace' @param ignoremods a list of the names of modules to ignore @param ignoredirs a list of the names of directories to ignore all of the (recursive) contents of @param infile file from which to read stored counts to be added into the results @param outfile file in which to write the results @param timing true iff timing information be displayed """ self.infile = infile self.outfile = outfile self.ignore = Ignore(ignoremods, ignoredirs) self.counts = {} # keys are (filename, linenumber) self.blabbed = {} # for debugging self.pathtobasename = {} # for memoizing os.path.basename self.donothing = 0 self.trace = trace self._calledfuncs = {} self._callers = {} self._caller_cache = {} self.start_time = None if timing: self.start_time = time.time() if countcallers: self.globaltrace = self.globaltrace_trackcallers elif countfuncs: self.globaltrace = self.globaltrace_countfuncs elif trace and count: self.globaltrace = self.globaltrace_lt self.localtrace = self.localtrace_trace_and_count elif trace: self.globaltrace = self.globaltrace_lt self.localtrace = self.localtrace_trace elif count: self.globaltrace = self.globaltrace_lt self.localtrace = self.localtrace_count else: # Ahem -- do nothing? Okay. self.donothing = 1 def run(self, cmd): import __main__ dict = __main__.__dict__ self.runctx(cmd, dict, dict) def runctx(self, cmd, globals=None, locals=None): if globals is None: globals = {} if locals is None: locals = {} if not self.donothing: _settrace(self.globaltrace) try: exec cmd in globals, locals finally: if not self.donothing: _unsettrace() def runfunc(self, func, *args, **kw): result = None if not self.donothing: sys.settrace(self.globaltrace) try: result = func(*args, **kw) finally: if not self.donothing: sys.settrace(None) return result def file_module_function_of(self, frame): code = frame.f_code filename = code.co_filename if filename: modulename = modname(filename) else: modulename = None funcname = code.co_name clsname = None if code in self._caller_cache: if self._caller_cache[code] is not None: clsname = self._caller_cache[code] else: self._caller_cache[code] = None ## use of gc.get_referrers() was suggested by Michael Hudson # all functions which refer to this code object funcs = [f for f in gc.get_referrers(code) if inspect.isfunction(f)] # require len(func) == 1 to avoid ambiguity caused by calls to # new.function(): "In the face of ambiguity, refuse the # temptation to guess." if len(funcs) == 1: dicts = [d for d in gc.get_referrers(funcs[0]) if isinstance(d, dict)] if len(dicts) == 1: classes = [c for c in gc.get_referrers(dicts[0]) if hasattr(c, "__bases__")] if len(classes) == 1: # ditto for new.classobj() clsname = classes[0].__name__ # cache the result - assumption is that new.* is # not called later to disturb this relationship # _caller_cache could be flushed if functions in # the new module get called. self._caller_cache[code] = clsname if clsname is not None: funcname = "%s.%s" % (clsname, funcname) return filename, modulename, funcname def globaltrace_trackcallers(self, frame, why, arg): """Handler for call events. Adds information about who called who to the self._callers dict. """ if why == 'call': # XXX Should do a better job of identifying methods this_func = self.file_module_function_of(frame) parent_func = self.file_module_function_of(frame.f_back) self._callers[(parent_func, this_func)] = 1 def globaltrace_countfuncs(self, frame, why, arg): """Handler for call events. Adds (filename, modulename, funcname) to the self._calledfuncs dict. """ if why == 'call': this_func = self.file_module_function_of(frame) self._calledfuncs[this_func] = 1 def globaltrace_lt(self, frame, why, arg): """Handler for call events. If the code block being entered is to be ignored, returns `None', else returns self.localtrace. """ if why == 'call': code = frame.f_code filename = frame.f_globals.get('__file__', None) if filename: # XXX modname() doesn't work right for packages, so # the ignore support won't work right for packages modulename = modname(filename) if modulename is not None: ignore_it = self.ignore.names(filename, modulename) if not ignore_it: if self.trace: print (" --- modulename: %s, funcname: %s" % (modulename, code.co_name)) return self.localtrace else: return None def localtrace_trace_and_count(self, frame, why, arg): if why == "line": # record the file name and line number of every trace filename = frame.f_code.co_filename lineno = frame.f_lineno key = filename, lineno self.counts[key] = self.counts.get(key, 0) + 1 if self.start_time: print '%.2f' % (time.time() - self.start_time), bname = os.path.basename(filename) print "%s(%d): %s" % (bname, lineno, linecache.getline(filename, lineno)), return self.localtrace def localtrace_trace(self, frame, why, arg): if why == "line": # record the file name and line number of every trace filename = frame.f_code.co_filename lineno = frame.f_lineno if self.start_time: print '%.2f' % (time.time() - self.start_time), bname = os.path.basename(filename) print "%s(%d): %s" % (bname, lineno, linecache.getline(filename, lineno)), return self.localtrace def localtrace_count(self, frame, why, arg): if why == "line": filename = frame.f_code.co_filename lineno = frame.f_lineno key = filename, lineno self.counts[key] = self.counts.get(key, 0) + 1 return self.localtrace def results(self): return CoverageResults(self.counts, infile=self.infile, outfile=self.outfile, calledfuncs=self._calledfuncs, callers=self._callers) def _err_exit(msg): sys.stderr.write("%s: %s\n" % (sys.argv[0], msg)) sys.exit(1) def main(argv=None): import getopt if argv is None: argv = sys.argv try: opts, prog_argv = getopt.getopt(argv[1:], "tcrRf:d:msC:lTg", ["help", "version", "trace", "count", "report", "no-report", "summary", "file=", "missing", "ignore-module=", "ignore-dir=", "coverdir=", "listfuncs", "trackcalls", "timing"]) except getopt.error, msg: sys.stderr.write("%s: %s\n" % (sys.argv[0], msg)) sys.stderr.write("Try `%s --help' for more information\n" % sys.argv[0]) sys.exit(1) trace = 0 count = 0 report = 0 no_report = 0 counts_file = None missing = 0 ignore_modules = [] ignore_dirs = [] coverdir = None summary = 0 listfuncs = False countcallers = False timing = False for opt, val in opts: if opt == "--help": usage(sys.stdout) sys.exit(0) if opt == "--version": sys.stdout.write("trace 2.0\n") sys.exit(0) if opt == "-T" or opt == "--trackcalls": countcallers = True continue if opt == "-l" or opt == "--listfuncs": listfuncs = True continue if opt == "-g" or opt == "--timing": timing = True continue if opt == "-t" or opt == "--trace": trace = 1 continue if opt == "-c" or opt == "--count": count = 1 continue if opt == "-r" or opt == "--report": report = 1 continue if opt == "-R" or opt == "--no-report": no_report = 1 continue if opt == "-f" or opt == "--file": counts_file = val continue if opt == "-m" or opt == "--missing": missing = 1 continue if opt == "-C" or opt == "--coverdir": coverdir = val continue if opt == "-s" or opt == "--summary": summary = 1 continue if opt == "--ignore-module": for mod in val.split(","): ignore_modules.append(mod.strip()) continue if opt == "--ignore-dir": for s in val.split(os.pathsep): s = os.path.expandvars(s) # should I also call expanduser? (after all, could use $HOME) s = s.replace("$prefix", os.path.join(sys.prefix, "lib", "python" + sys.version[:3])) s = s.replace("$exec_prefix", os.path.join(sys.exec_prefix, "lib", "python" + sys.version[:3])) s = os.path.normpath(s) ignore_dirs.append(s) continue assert 0, "Should never get here" if listfuncs and (count or trace): _err_exit("cannot specify both --listfuncs and (--trace or --count)") if not (count or trace or report or listfuncs or countcallers): _err_exit("must specify one of --trace, --count, --report, " "--listfuncs, or --trackcalls") if report and no_report: _err_exit("cannot specify both --report and --no-report") if report and not counts_file: _err_exit("--report requires a --file") if no_report and len(prog_argv) == 0: _err_exit("missing name of file to run") # everything is ready if report: results = CoverageResults(infile=counts_file, outfile=counts_file) results.write_results(missing, summary=summary, coverdir=coverdir) else: sys.argv = prog_argv progname = prog_argv[0] sys.path[0] = os.path.split(progname)[0] t = Trace(count, trace, countfuncs=listfuncs, countcallers=countcallers, ignoremods=ignore_modules, ignoredirs=ignore_dirs, infile=counts_file, outfile=counts_file, timing=timing) try: with open(progname) as fp: code = compile(fp.read(), progname, 'exec') # try to emulate __main__ namespace as much as possible globs = { '__file__': progname, '__name__': '__main__', '__package__': None, '__cached__': None, } t.runctx(code, globs, globs) except IOError, err: _err_exit("Cannot run file %r because: %s" % (sys.argv[0], err)) except SystemExit: pass results = t.results() if not no_report: results.write_results(missing, summary=summary, coverdir=coverdir) if __name__=='__main__': main()