golden hour
/opt/alt/python27/lib64/python2.7
⬆️ Go Up
Upload
File/Folder
Size
Actions
BaseHTTPServer.py
22.21 KB
Del
OK
BaseHTTPServer.pyc
21.47 KB
Del
OK
BaseHTTPServer.pyo
21.47 KB
Del
OK
Bastion.py
5.61 KB
Del
OK
Bastion.pyc
6.69 KB
Del
OK
Bastion.pyo
6.69 KB
Del
OK
CGIHTTPServer.py
12.78 KB
Del
OK
CGIHTTPServer.pyc
10.92 KB
Del
OK
CGIHTTPServer.pyo
10.92 KB
Del
OK
ConfigParser.py
27.1 KB
Del
OK
ConfigParser.pyc
25.37 KB
Del
OK
ConfigParser.pyo
25.37 KB
Del
OK
Cookie.py
25.92 KB
Del
OK
Cookie.pyc
22.61 KB
Del
OK
Cookie.pyo
22.61 KB
Del
OK
DocXMLRPCServer.py
10.52 KB
Del
OK
DocXMLRPCServer.pyc
10.2 KB
Del
OK
DocXMLRPCServer.pyo
10.09 KB
Del
OK
HTMLParser.py
16.77 KB
Del
OK
HTMLParser.pyc
13.81 KB
Del
OK
HTMLParser.pyo
13.51 KB
Del
OK
MimeWriter.py
6.33 KB
Del
OK
MimeWriter.pyc
7.31 KB
Del
OK
MimeWriter.pyo
7.31 KB
Del
OK
Queue.py
8.38 KB
Del
OK
Queue.pyc
9.56 KB
Del
OK
Queue.pyo
9.56 KB
Del
OK
SimpleHTTPServer.py
7.81 KB
Del
OK
SimpleHTTPServer.pyc
7.96 KB
Del
OK
SimpleHTTPServer.pyo
7.96 KB
Del
OK
SimpleXMLRPCServer.py
25.21 KB
Del
OK
SimpleXMLRPCServer.pyc
22.78 KB
Del
OK
SimpleXMLRPCServer.pyo
22.78 KB
Del
OK
SocketServer.py
23.39 KB
Del
OK
SocketServer.pyc
24.25 KB
Del
OK
SocketServer.pyo
24.25 KB
Del
OK
StringIO.py
10.41 KB
Del
OK
StringIO.pyc
11.45 KB
Del
OK
StringIO.pyo
11.45 KB
Del
OK
UserDict.py
6.89 KB
Del
OK
UserDict.pyc
10.05 KB
Del
OK
UserDict.pyo
10.05 KB
Del
OK
UserList.py
3.56 KB
Del
OK
UserList.pyc
6.85 KB
Del
OK
UserList.pyo
6.85 KB
Del
OK
UserString.py
9.47 KB
Del
OK
UserString.pyc
15.38 KB
Del
OK
UserString.pyo
15.38 KB
Del
OK
_LWPCookieJar.py
6.4 KB
Del
OK
_LWPCookieJar.pyc
5.38 KB
Del
OK
_LWPCookieJar.pyo
5.38 KB
Del
OK
_MozillaCookieJar.py
5.66 KB
Del
OK
_MozillaCookieJar.pyc
4.41 KB
Del
OK
_MozillaCookieJar.pyo
4.37 KB
Del
OK
__future__.py
4.28 KB
Del
OK
__future__.pyc
4.2 KB
Del
OK
__future__.pyo
4.2 KB
Del
OK
__phello__.foo.py
64 B
Del
OK
__phello__.foo.pyc
138 B
Del
OK
__phello__.foo.pyo
138 B
Del
OK
_abcoll.py
18.18 KB
Del
OK
_abcoll.pyc
26.4 KB
Del
OK
_abcoll.pyo
26.4 KB
Del
OK
_osx_support.py
18.65 KB
Del
OK
_osx_support.pyc
11.72 KB
Del
OK
_osx_support.pyo
11.72 KB
Del
OK
_pyio.py
68 KB
Del
OK
_pyio.pyc
65.41 KB
Del
OK
_pyio.pyo
65.41 KB
Del
OK
_strptime.py
20.24 KB
Del
OK
_strptime.pyc
15.07 KB
Del
OK
_strptime.pyo
15.07 KB
Del
OK
_sysconfigdata.py
18.9 KB
Del
OK
_sysconfigdata.pyc
22 KB
Del
OK
_sysconfigdata.pyo
22 KB
Del
OK
_threading_local.py
7.09 KB
Del
OK
_threading_local.pyc
6.34 KB
Del
OK
_threading_local.pyo
6.34 KB
Del
OK
_weakrefset.py
5.77 KB
Del
OK
_weakrefset.pyc
10.06 KB
Del
OK
_weakrefset.pyo
10.06 KB
Del
OK
abc.py
6.98 KB
Del
OK
abc.pyc
6.14 KB
Del
OK
abc.pyo
6.08 KB
Del
OK
aifc.py
33.77 KB
Del
OK
aifc.pyc
30.67 KB
Del
OK
aifc.pyo
30.67 KB
Del
OK
antigravity.py
60 B
Del
OK
antigravity.pyc
216 B
Del
OK
antigravity.pyo
216 B
Del
OK
anydbm.py
2.6 KB
Del
OK
anydbm.pyc
2.77 KB
Del
OK
anydbm.pyo
2.77 KB
Del
OK
argparse.py
87.14 KB
Del
OK
argparse.pyc
64.83 KB
Del
OK
argparse.pyo
64.67 KB
Del
OK
ast.py
11.53 KB
Del
OK
ast.pyc
12.94 KB
Del
OK
ast.pyo
12.94 KB
Del
OK
asynchat.py
11.31 KB
Del
OK
asynchat.pyc
8.98 KB
Del
OK
asynchat.pyo
8.98 KB
Del
OK
asyncore.py
20.45 KB
Del
OK
asyncore.pyc
19.2 KB
Del
OK
asyncore.pyo
19.2 KB
Del
OK
atexit.py
1.67 KB
Del
OK
atexit.pyc
2.23 KB
Del
OK
atexit.pyo
2.23 KB
Del
OK
audiodev.py
7.42 KB
Del
OK
audiodev.pyc
8.61 KB
Del
OK
audiodev.pyo
8.61 KB
Del
OK
base64.py
11.54 KB
Del
OK
base64.pyc
11.26 KB
Del
OK
base64.pyo
11.26 KB
Del
OK
bdb.py
21.21 KB
Del
OK
bdb.pyc
19.43 KB
Del
OK
bdb.pyo
19.43 KB
Del
OK
binhex.py
14.35 KB
Del
OK
binhex.pyc
15.75 KB
Del
OK
binhex.pyo
15.75 KB
Del
OK
bisect.py
2.53 KB
Del
OK
bisect.pyc
3.06 KB
Del
OK
bisect.pyo
3.06 KB
Del
OK
bsddb
-
Del
OK
cProfile.py
6.43 KB
Del
OK
cProfile.pyc
6.42 KB
Del
OK
cProfile.pyo
6.42 KB
Del
OK
calendar.py
22.84 KB
Del
OK
calendar.pyc
28.26 KB
Del
OK
calendar.pyo
28.26 KB
Del
OK
cgi.py
34.97 KB
Del
OK
cgi.pyc
33.24 KB
Del
OK
cgi.pyo
33.24 KB
Del
OK
cgitb.py
11.89 KB
Del
OK
cgitb.pyc
12.08 KB
Del
OK
cgitb.pyo
12.08 KB
Del
OK
chunk.py
5.29 KB
Del
OK
chunk.pyc
5.61 KB
Del
OK
chunk.pyo
5.61 KB
Del
OK
cmd.py
14.67 KB
Del
OK
cmd.pyc
13.98 KB
Del
OK
cmd.pyo
13.98 KB
Del
OK
code.py
9.95 KB
Del
OK
code.pyc
10.29 KB
Del
OK
code.pyo
10.29 KB
Del
OK
codecs.py
35.3 KB
Del
OK
codecs.pyc
37.15 KB
Del
OK
codecs.pyo
37.15 KB
Del
OK
codeop.py
5.86 KB
Del
OK
codeop.pyc
6.57 KB
Del
OK
codeop.pyo
6.57 KB
Del
OK
collections.py
27.15 KB
Del
OK
collections.pyc
26.21 KB
Del
OK
collections.pyo
26.16 KB
Del
OK
colorsys.py
3.6 KB
Del
OK
colorsys.pyc
4 KB
Del
OK
colorsys.pyo
4 KB
Del
OK
commands.py
2.49 KB
Del
OK
commands.pyc
2.49 KB
Del
OK
commands.pyo
2.49 KB
Del
OK
compileall.py
7.58 KB
Del
OK
compileall.pyc
6.93 KB
Del
OK
compileall.pyo
6.93 KB
Del
OK
compiler
-
Del
OK
config
-
Del
OK
contextlib.py
4.32 KB
Del
OK
contextlib.pyc
4.5 KB
Del
OK
contextlib.pyo
4.5 KB
Del
OK
cookielib.py
63.95 KB
Del
OK
cookielib.pyc
54.67 KB
Del
OK
cookielib.pyo
54.49 KB
Del
OK
copy.py
11.26 KB
Del
OK
copy.pyc
12.21 KB
Del
OK
copy.pyo
12.13 KB
Del
OK
copy_reg.py
6.81 KB
Del
OK
copy_reg.pyc
5.19 KB
Del
OK
copy_reg.pyo
5.14 KB
Del
OK
crypt.py
2.24 KB
Del
OK
crypt.pyc
2.95 KB
Del
OK
crypt.pyo
2.95 KB
Del
OK
csv.py
16.32 KB
Del
OK
csv.pyc
13.56 KB
Del
OK
csv.pyo
13.56 KB
Del
OK
ctypes
-
Del
OK
curses
-
Del
OK
dbhash.py
498 B
Del
OK
dbhash.pyc
744 B
Del
OK
dbhash.pyo
744 B
Del
OK
decimal.py
216.73 KB
Del
OK
decimal.pyc
171.36 KB
Del
OK
decimal.pyo
171.36 KB
Del
OK
difflib.py
80.4 KB
Del
OK
difflib.pyc
61.13 KB
Del
OK
difflib.pyo
61.08 KB
Del
OK
dircache.py
1.1 KB
Del
OK
dircache.pyc
1.59 KB
Del
OK
dircache.pyo
1.59 KB
Del
OK
dis.py
6.35 KB
Del
OK
dis.pyc
6.18 KB
Del
OK
dis.pyo
6.18 KB
Del
OK
distutils
-
Del
OK
doctest.py
102.63 KB
Del
OK
doctest.pyc
83.21 KB
Del
OK
doctest.pyo
82.93 KB
Del
OK
dumbdbm.py
8.93 KB
Del
OK
dumbdbm.pyc
6.83 KB
Del
OK
dumbdbm.pyo
6.83 KB
Del
OK
dummy_thread.py
4.31 KB
Del
OK
dummy_thread.pyc
5.46 KB
Del
OK
dummy_thread.pyo
5.46 KB
Del
OK
dummy_threading.py
2.74 KB
Del
OK
dummy_threading.pyc
1.27 KB
Del
OK
dummy_threading.pyo
1.27 KB
Del
OK
email
-
Del
OK
encodings
-
Del
OK
ensurepip
-
Del
OK
filecmp.py
9.36 KB
Del
OK
filecmp.pyc
9.65 KB
Del
OK
filecmp.pyo
9.65 KB
Del
OK
fileinput.py
13.42 KB
Del
OK
fileinput.pyc
14.54 KB
Del
OK
fileinput.pyo
14.54 KB
Del
OK
fnmatch.py
3.24 KB
Del
OK
fnmatch.pyc
3.61 KB
Del
OK
fnmatch.pyo
3.61 KB
Del
OK
formatter.py
14.56 KB
Del
OK
formatter.pyc
19.71 KB
Del
OK
formatter.pyo
19.71 KB
Del
OK
fpformat.py
4.62 KB
Del
OK
fpformat.pyc
4.69 KB
Del
OK
fpformat.pyo
4.69 KB
Del
OK
fractions.py
21.87 KB
Del
OK
fractions.pyc
19.74 KB
Del
OK
fractions.pyo
19.74 KB
Del
OK
ftplib.py
37.3 KB
Del
OK
ftplib.pyc
34.82 KB
Del
OK
ftplib.pyo
34.82 KB
Del
OK
functools.py
4.69 KB
Del
OK
functools.pyc
6.85 KB
Del
OK
functools.pyo
6.85 KB
Del
OK
genericpath.py
3.13 KB
Del
OK
genericpath.pyc
3.57 KB
Del
OK
genericpath.pyo
3.57 KB
Del
OK
getopt.py
7.15 KB
Del
OK
getopt.pyc
6.63 KB
Del
OK
getopt.pyo
6.58 KB
Del
OK
getpass.py
5.43 KB
Del
OK
getpass.pyc
4.72 KB
Del
OK
getpass.pyo
4.72 KB
Del
OK
gettext.py
22.13 KB
Del
OK
gettext.pyc
18.17 KB
Del
OK
gettext.pyo
18.17 KB
Del
OK
glob.py
3.04 KB
Del
OK
glob.pyc
2.98 KB
Del
OK
glob.pyo
2.98 KB
Del
OK
gzip.py
18.58 KB
Del
OK
gzip.pyc
15.26 KB
Del
OK
gzip.pyo
15.26 KB
Del
OK
hashlib.py
7.66 KB
Del
OK
hashlib.pyc
6.86 KB
Del
OK
hashlib.pyo
6.86 KB
Del
OK
heapq.py
17.87 KB
Del
OK
heapq.pyc
14.45 KB
Del
OK
heapq.pyo
14.45 KB
Del
OK
hmac.py
4.48 KB
Del
OK
hmac.pyc
4.56 KB
Del
OK
hmac.pyo
4.56 KB
Del
OK
hotshot
-
Del
OK
htmlentitydefs.py
17.63 KB
Del
OK
htmlentitydefs.pyc
6.23 KB
Del
OK
htmlentitydefs.pyo
6.23 KB
Del
OK
htmllib.py
12.57 KB
Del
OK
htmllib.pyc
20.99 KB
Del
OK
htmllib.pyo
20.99 KB
Del
OK
httplib.py
51.07 KB
Del
OK
httplib.pyc
37.88 KB
Del
OK
httplib.pyo
37.7 KB
Del
OK
idlelib
-
Del
OK
ihooks.py
18.54 KB
Del
OK
ihooks.pyc
21.75 KB
Del
OK
ihooks.pyo
21.75 KB
Del
OK
imaplib.py
47.23 KB
Del
OK
imaplib.pyc
45.19 KB
Del
OK
imaplib.pyo
42.49 KB
Del
OK
imghdr.py
3.46 KB
Del
OK
imghdr.pyc
4.93 KB
Del
OK
imghdr.pyo
4.93 KB
Del
OK
importlib
-
Del
OK
imputil.py
25.16 KB
Del
OK
imputil.pyc
15.74 KB
Del
OK
imputil.pyo
15.57 KB
Del
OK
inspect.py
42 KB
Del
OK
inspect.pyc
40.16 KB
Del
OK
inspect.pyo
40.16 KB
Del
OK
io.py
3.24 KB
Del
OK
io.pyc
3.57 KB
Del
OK
io.pyo
3.57 KB
Del
OK
json
-
Del
OK
keyword.py
1.96 KB
Del
OK
keyword.pyc
2.08 KB
Del
OK
keyword.pyo
2.08 KB
Del
OK
lib-dynload
-
Del
OK
lib2to3
-
Del
OK
linecache.py
3.93 KB
Del
OK
linecache.pyc
3.27 KB
Del
OK
linecache.pyo
3.27 KB
Del
OK
locale.py
100.42 KB
Del
OK
locale.pyc
55.69 KB
Del
OK
locale.pyo
55.69 KB
Del
OK
logging
-
Del
OK
macpath.py
6.14 KB
Del
OK
macpath.pyc
7.74 KB
Del
OK
macpath.pyo
7.74 KB
Del
OK
macurl2path.py
2.67 KB
Del
OK
macurl2path.pyc
2.24 KB
Del
OK
macurl2path.pyo
2.24 KB
Del
OK
mailbox.py
79.34 KB
Del
OK
mailbox.pyc
77.7 KB
Del
OK
mailbox.pyo
77.65 KB
Del
OK
mailcap.py
7.25 KB
Del
OK
mailcap.pyc
7.08 KB
Del
OK
mailcap.pyo
7.08 KB
Del
OK
markupbase.py
14.3 KB
Del
OK
markupbase.pyc
9.27 KB
Del
OK
markupbase.pyo
9.07 KB
Del
OK
md5.py
358 B
Del
OK
md5.pyc
391 B
Del
OK
md5.pyo
391 B
Del
OK
mhlib.py
32.65 KB
Del
OK
mhlib.pyc
33.98 KB
Del
OK
mhlib.pyo
33.98 KB
Del
OK
mimetools.py
7 KB
Del
OK
mimetools.pyc
8.26 KB
Del
OK
mimetools.pyo
8.26 KB
Del
OK
mimetypes.py
20.54 KB
Del
OK
mimetypes.pyc
18.3 KB
Del
OK
mimetypes.pyo
18.3 KB
Del
OK
mimify.py
14.68 KB
Del
OK
mimify.pyc
11.91 KB
Del
OK
mimify.pyo
11.91 KB
Del
OK
modulefinder.py
23.89 KB
Del
OK
modulefinder.pyc
19.12 KB
Del
OK
modulefinder.pyo
19.04 KB
Del
OK
multifile.py
4.71 KB
Del
OK
multifile.pyc
5.48 KB
Del
OK
multifile.pyo
5.44 KB
Del
OK
multiprocessing
-
Del
OK
mutex.py
1.83 KB
Del
OK
mutex.pyc
2.55 KB
Del
OK
mutex.pyo
2.55 KB
Del
OK
netrc.py
5.75 KB
Del
OK
netrc.pyc
4.72 KB
Del
OK
netrc.pyo
4.72 KB
Del
OK
new.py
610 B
Del
OK
new.pyc
875 B
Del
OK
new.pyo
875 B
Del
OK
nntplib.py
20.97 KB
Del
OK
nntplib.pyc
21.11 KB
Del
OK
nntplib.pyo
21.11 KB
Del
OK
ntpath.py
18.97 KB
Del
OK
ntpath.pyc
13.1 KB
Del
OK
ntpath.pyo
13.1 KB
Del
OK
nturl2path.py
2.36 KB
Del
OK
nturl2path.pyc
1.81 KB
Del
OK
nturl2path.pyo
1.81 KB
Del
OK
numbers.py
10.08 KB
Del
OK
numbers.pyc
14.47 KB
Del
OK
numbers.pyo
14.47 KB
Del
OK
opcode.py
5.35 KB
Del
OK
opcode.pyc
6.06 KB
Del
OK
opcode.pyo
6.06 KB
Del
OK
optparse.py
59.77 KB
Del
OK
optparse.pyc
54.41 KB
Del
OK
optparse.pyo
54.33 KB
Del
OK
os.py
25.3 KB
Del
OK
os.pyc
25.76 KB
Del
OK
os.pyo
25.76 KB
Del
OK
os2emxpath.py
4.53 KB
Del
OK
os2emxpath.pyc
4.53 KB
Del
OK
os2emxpath.pyo
4.53 KB
Del
OK
pdb.doc
7.73 KB
Del
OK
pdb.py
45.03 KB
Del
OK
pdb.pyc
44.09 KB
Del
OK
pdb.pyo
44.09 KB
Del
OK
pickle.py
44.42 KB
Del
OK
pickle.pyc
38.98 KB
Del
OK
pickle.pyo
38.79 KB
Del
OK
pickletools.py
72.78 KB
Del
OK
pickletools.pyc
56.1 KB
Del
OK
pickletools.pyo
55.26 KB
Del
OK
pipes.py
9.36 KB
Del
OK
pipes.pyc
9.29 KB
Del
OK
pipes.pyo
9.29 KB
Del
OK
pkgutil.py
19.77 KB
Del
OK
pkgutil.pyc
18.93 KB
Del
OK
pkgutil.pyo
18.93 KB
Del
OK
plat-linux2
-
Del
OK
platform.py
51.56 KB
Del
OK
platform.pyc
37.7 KB
Del
OK
platform.pyo
37.7 KB
Del
OK
plistlib.py
14.83 KB
Del
OK
plistlib.pyc
19.54 KB
Del
OK
plistlib.pyo
19.46 KB
Del
OK
popen2.py
8.22 KB
Del
OK
popen2.pyc
9.02 KB
Del
OK
popen2.pyo
8.98 KB
Del
OK
poplib.py
12.52 KB
Del
OK
poplib.pyc
13.45 KB
Del
OK
poplib.pyo
13.45 KB
Del
OK
posixfile.py
7.82 KB
Del
OK
posixfile.pyc
7.63 KB
Del
OK
posixfile.pyo
7.63 KB
Del
OK
posixpath.py
13.96 KB
Del
OK
posixpath.pyc
11.49 KB
Del
OK
posixpath.pyo
11.49 KB
Del
OK
pprint.py
11.5 KB
Del
OK
pprint.pyc
10.2 KB
Del
OK
pprint.pyo
10.02 KB
Del
OK
profile.py
22.26 KB
Del
OK
profile.pyc
16.57 KB
Del
OK
profile.pyo
16.32 KB
Del
OK
pstats.py
26.09 KB
Del
OK
pstats.pyc
25.19 KB
Del
OK
pstats.pyo
25.19 KB
Del
OK
pty.py
4.94 KB
Del
OK
pty.pyc
4.98 KB
Del
OK
pty.pyo
4.98 KB
Del
OK
py_compile.py
5.8 KB
Del
OK
py_compile.pyc
6.37 KB
Del
OK
py_compile.pyo
6.37 KB
Del
OK
pyclbr.py
13.07 KB
Del
OK
pyclbr.pyc
9.59 KB
Del
OK
pyclbr.pyo
9.59 KB
Del
OK
pydoc.py
93.43 KB
Del
OK
pydoc.pyc
92.69 KB
Del
OK
pydoc.pyo
92.63 KB
Del
OK
pydoc_data
-
Del
OK
quopri.py
6.81 KB
Del
OK
quopri.pyc
6.56 KB
Del
OK
quopri.pyo
6.56 KB
Del
OK
random.py
31.7 KB
Del
OK
random.pyc
25.65 KB
Del
OK
random.pyo
25.65 KB
Del
OK
re.py
13.11 KB
Del
OK
re.pyc
13.37 KB
Del
OK
re.pyo
13.37 KB
Del
OK
repr.py
4.2 KB
Del
OK
repr.pyc
5.47 KB
Del
OK
repr.pyo
5.47 KB
Del
OK
rexec.py
19.68 KB
Del
OK
rexec.pyc
24 KB
Del
OK
rexec.pyo
24 KB
Del
OK
rfc822.py
32.76 KB
Del
OK
rfc822.pyc
31.83 KB
Del
OK
rfc822.pyo
31.83 KB
Del
OK
rlcompleter.py
5.85 KB
Del
OK
rlcompleter.pyc
6.04 KB
Del
OK
rlcompleter.pyo
6.04 KB
Del
OK
robotparser.py
7.51 KB
Del
OK
robotparser.pyc
8.12 KB
Del
OK
robotparser.pyo
8.12 KB
Del
OK
runpy.py
10.82 KB
Del
OK
runpy.pyc
8.85 KB
Del
OK
runpy.pyo
8.85 KB
Del
OK
sched.py
4.97 KB
Del
OK
sched.pyc
4.99 KB
Del
OK
sched.pyo
4.99 KB
Del
OK
sets.py
18.6 KB
Del
OK
sets.pyc
17.21 KB
Del
OK
sets.pyo
17.21 KB
Del
OK
sgmllib.py
17.46 KB
Del
OK
sgmllib.pyc
15.67 KB
Del
OK
sgmllib.pyo
15.67 KB
Del
OK
sha.py
393 B
Del
OK
sha.pyc
434 B
Del
OK
sha.pyo
434 B
Del
OK
shelve.py
7.99 KB
Del
OK
shelve.pyc
10.36 KB
Del
OK
shelve.pyo
10.36 KB
Del
OK
shlex.py
10.9 KB
Del
OK
shlex.pyc
7.55 KB
Del
OK
shlex.pyo
7.55 KB
Del
OK
shutil.py
19.41 KB
Del
OK
shutil.pyc
19.19 KB
Del
OK
shutil.pyo
19.19 KB
Del
OK
site-packages
-
Del
OK
site.py
19.18 KB
Del
OK
site.pyc
19.35 KB
Del
OK
site.pyo
19.35 KB
Del
OK
smtpd.py
18.12 KB
Del
OK
smtpd.pyc
15.9 KB
Del
OK
smtpd.pyo
15.9 KB
Del
OK
smtplib.py
31.39 KB
Del
OK
smtplib.pyc
30.29 KB
Del
OK
smtplib.pyo
30.29 KB
Del
OK
sndhdr.py
5.83 KB
Del
OK
sndhdr.pyc
7.4 KB
Del
OK
sndhdr.pyo
7.4 KB
Del
OK
socket.py
20.13 KB
Del
OK
socket.pyc
16.15 KB
Del
OK
socket.pyo
16.07 KB
Del
OK
sqlite3
-
Del
OK
sre.py
384 B
Del
OK
sre.pyc
532 B
Del
OK
sre.pyo
532 B
Del
OK
sre_compile.py
19.36 KB
Del
OK
sre_compile.pyc
12.46 KB
Del
OK
sre_compile.pyo
12.3 KB
Del
OK
sre_constants.py
7.03 KB
Del
OK
sre_constants.pyc
6.11 KB
Del
OK
sre_constants.pyo
6.11 KB
Del
OK
sre_parse.py
29.98 KB
Del
OK
sre_parse.pyc
21.12 KB
Del
OK
sre_parse.pyo
21.12 KB
Del
OK
ssl.py
36.58 KB
Del
OK
ssl.pyc
32.24 KB
Del
OK
ssl.pyo
32.24 KB
Del
OK
stat.py
1.8 KB
Del
OK
stat.pyc
2.81 KB
Del
OK
stat.pyo
2.81 KB
Del
OK
statvfs.py
898 B
Del
OK
statvfs.pyc
633 B
Del
OK
statvfs.pyo
633 B
Del
OK
string.py
21.04 KB
Del
OK
string.pyc
20.63 KB
Del
OK
string.pyo
20.63 KB
Del
OK
stringold.py
12.16 KB
Del
OK
stringold.pyc
12.6 KB
Del
OK
stringold.pyo
12.6 KB
Del
OK
stringprep.py
13.21 KB
Del
OK
stringprep.pyc
14.4 KB
Del
OK
stringprep.pyo
14.33 KB
Del
OK
struct.py
82 B
Del
OK
struct.pyc
252 B
Del
OK
struct.pyo
252 B
Del
OK
subprocess.py
49.34 KB
Del
OK
subprocess.pyc
32.32 KB
Del
OK
subprocess.pyo
32.32 KB
Del
OK
sunau.py
16.82 KB
Del
OK
sunau.pyc
18.57 KB
Del
OK
sunau.pyo
18.57 KB
Del
OK
sunaudio.py
1.37 KB
Del
OK
sunaudio.pyc
2 KB
Del
OK
sunaudio.pyo
2 KB
Del
OK
symbol.py
2.02 KB
Del
OK
symbol.pyc
2.98 KB
Del
OK
symbol.pyo
2.98 KB
Del
OK
symtable.py
7.26 KB
Del
OK
symtable.pyc
12.14 KB
Del
OK
symtable.pyo
12.02 KB
Del
OK
sysconfig.py
22.32 KB
Del
OK
sysconfig.pyc
17.73 KB
Del
OK
sysconfig.pyo
17.73 KB
Del
OK
tabnanny.py
11.08 KB
Del
OK
tabnanny.pyc
8.31 KB
Del
OK
tabnanny.pyo
8.31 KB
Del
OK
tarfile.py
88.45 KB
Del
OK
tarfile.pyc
76.54 KB
Del
OK
tarfile.pyo
76.54 KB
Del
OK
telnetlib.py
26.4 KB
Del
OK
telnetlib.pyc
23.03 KB
Del
OK
telnetlib.pyo
23.03 KB
Del
OK
tempfile.py
19.09 KB
Del
OK
tempfile.pyc
20.55 KB
Del
OK
tempfile.pyo
20.55 KB
Del
OK
test
-
Del
OK
textwrap.py
16.88 KB
Del
OK
textwrap.pyc
11.99 KB
Del
OK
textwrap.pyo
11.9 KB
Del
OK
this.py
1002 B
Del
OK
this.pyc
1.2 KB
Del
OK
this.pyo
1.2 KB
Del
OK
threading.py
46.17 KB
Del
OK
threading.pyc
42.97 KB
Del
OK
threading.pyo
40.84 KB
Del
OK
timeit.py
12.5 KB
Del
OK
timeit.pyc
12.06 KB
Del
OK
timeit.pyo
12.06 KB
Del
OK
toaiff.py
3.07 KB
Del
OK
toaiff.pyc
3.08 KB
Del
OK
toaiff.pyo
3.08 KB
Del
OK
token.py
2.85 KB
Del
OK
token.pyc
3.79 KB
Del
OK
token.pyo
3.79 KB
Del
OK
tokenize.py
17.07 KB
Del
OK
tokenize.pyc
14.37 KB
Del
OK
tokenize.pyo
14.31 KB
Del
OK
trace.py
29.2 KB
Del
OK
trace.pyc
22.69 KB
Del
OK
trace.pyo
22.63 KB
Del
OK
traceback.py
11.02 KB
Del
OK
traceback.pyc
11.66 KB
Del
OK
traceback.pyo
11.66 KB
Del
OK
tty.py
879 B
Del
OK
tty.pyc
1.32 KB
Del
OK
tty.pyo
1.32 KB
Del
OK
types.py
2.04 KB
Del
OK
types.pyc
2.75 KB
Del
OK
types.pyo
2.75 KB
Del
OK
unittest
-
Del
OK
urllib.py
58.82 KB
Del
OK
urllib.pyc
51.35 KB
Del
OK
urllib.pyo
51.25 KB
Del
OK
urllib2.py
51.31 KB
Del
OK
urllib2.pyc
47.8 KB
Del
OK
urllib2.pyo
47.71 KB
Del
OK
urlparse.py
16.29 KB
Del
OK
urlparse.pyc
15.51 KB
Del
OK
urlparse.pyo
15.51 KB
Del
OK
user.py
1.59 KB
Del
OK
user.pyc
1.7 KB
Del
OK
user.pyo
1.7 KB
Del
OK
uu.py
6.55 KB
Del
OK
uu.pyc
4.35 KB
Del
OK
uu.pyo
4.35 KB
Del
OK
uuid.py
22.63 KB
Del
OK
uuid.pyc
23.22 KB
Del
OK
uuid.pyo
23.11 KB
Del
OK
warnings.py
14.48 KB
Del
OK
warnings.pyc
13.49 KB
Del
OK
warnings.pyo
12.71 KB
Del
OK
wave.py
18.15 KB
Del
OK
wave.pyc
20.19 KB
Del
OK
wave.pyo
20.05 KB
Del
OK
weakref.py
14.48 KB
Del
OK
weakref.pyc
16.73 KB
Del
OK
weakref.pyo
16.73 KB
Del
OK
webbrowser.py
22.2 KB
Del
OK
webbrowser.pyc
19.86 KB
Del
OK
webbrowser.pyo
19.81 KB
Del
OK
whichdb.py
3.31 KB
Del
OK
whichdb.pyc
2.21 KB
Del
OK
whichdb.pyo
2.21 KB
Del
OK
wsgiref
-
Del
OK
wsgiref.egg-info
187 B
Del
OK
xdrlib.py
5.93 KB
Del
OK
xdrlib.pyc
10.2 KB
Del
OK
xdrlib.pyo
10.2 KB
Del
OK
xml
-
Del
OK
xmllib.py
34.05 KB
Del
OK
xmllib.pyc
26.9 KB
Del
OK
xmllib.pyo
26.9 KB
Del
OK
xmlrpclib.py
50.91 KB
Del
OK
xmlrpclib.pyc
44.81 KB
Del
OK
xmlrpclib.pyo
44.63 KB
Del
OK
zipfile.py
58.08 KB
Del
OK
zipfile.pyc
41.92 KB
Del
OK
zipfile.pyo
41.92 KB
Del
OK
Edit: subprocess.py
# subprocess - Subprocesses with accessible I/O streams # # For more information about this module, see PEP 324. # # Copyright (c) 2003-2005 by Peter Astrand <astrand@lysator.liu.se> # # Licensed to PSF under a Contributor Agreement. # See http://www.python.org/2.4/license for licensing details. r"""Subprocesses with accessible I/O streams This module allows you to spawn processes, connect to their input/output/error pipes, and obtain their return codes. For a complete description of this module see the Python documentation. Main API ======== call(...): Runs a command, waits for it to complete, then returns the return code. check_call(...): Same as call() but raises CalledProcessError() if return code is not 0 check_output(...): Same as check_call() but returns the contents of stdout instead of a return code Popen(...): A class for flexibly executing a command in a new process Constants --------- PIPE: Special value that indicates a pipe should be created STDOUT: Special value that indicates that stderr should go to stdout """ import sys mswindows = (sys.platform == "win32") import os import types import traceback import gc import signal import errno # Exception classes used by this module. class CalledProcessError(Exception): """This exception is raised when a process run by check_call() or check_output() returns a non-zero exit status. Attributes: cmd, returncode, output """ def __init__(self, returncode, cmd, output=None): self.returncode = returncode self.cmd = cmd self.output = output def __str__(self): return "Command '%s' returned non-zero exit status %d" % (self.cmd, self.returncode) if mswindows: import threading import msvcrt import _subprocess class STARTUPINFO: dwFlags = 0 hStdInput = None hStdOutput = None hStdError = None wShowWindow = 0 class pywintypes: error = IOError else: import select _has_poll = hasattr(select, 'poll') try: import threading except ImportError: threading = None import fcntl import pickle # When select or poll has indicated that the file is writable, # we can write up to _PIPE_BUF bytes without risk of blocking. # POSIX defines PIPE_BUF as >= 512. _PIPE_BUF = getattr(select, 'PIPE_BUF', 512) __all__ = ["Popen", "PIPE", "STDOUT", "call", "check_call", "check_output", "CalledProcessError"] if mswindows: from _subprocess import (CREATE_NEW_CONSOLE, CREATE_NEW_PROCESS_GROUP, STD_INPUT_HANDLE, STD_OUTPUT_HANDLE, STD_ERROR_HANDLE, SW_HIDE, STARTF_USESTDHANDLES, STARTF_USESHOWWINDOW) __all__.extend(["CREATE_NEW_CONSOLE", "CREATE_NEW_PROCESS_GROUP", "STD_INPUT_HANDLE", "STD_OUTPUT_HANDLE", "STD_ERROR_HANDLE", "SW_HIDE", "STARTF_USESTDHANDLES", "STARTF_USESHOWWINDOW"]) try: MAXFD = os.sysconf("SC_OPEN_MAX") except: MAXFD = 256 _active = [] def _cleanup(): for inst in _active[:]: res = inst._internal_poll(_deadstate=sys.maxint) if res is not None: try: _active.remove(inst) except ValueError: # This can happen if two threads create a new Popen instance. # It's harmless that it was already removed, so ignore. pass PIPE = -1 STDOUT = -2 def _eintr_retry_call(func, *args): while True: try: return func(*args) except (OSError, IOError) as e: if e.errno == errno.EINTR: continue raise # XXX This function is only used by multiprocessing and the test suite, # but it's here so that it can be imported when Python is compiled without # threads. def _args_from_interpreter_flags(): """Return a list of command-line arguments reproducing the current settings in sys.flags and sys.warnoptions.""" flag_opt_map = { 'debug': 'd', # 'inspect': 'i', # 'interactive': 'i', 'optimize': 'O', 'dont_write_bytecode': 'B', 'no_user_site': 's', 'no_site': 'S', 'ignore_environment': 'E', 'verbose': 'v', 'bytes_warning': 'b', 'py3k_warning': '3', } args = [] for flag, opt in flag_opt_map.items(): v = getattr(sys.flags, flag) if v > 0: args.append('-' + opt * v) if getattr(sys.flags, 'hash_randomization') != 0: args.append('-R') for opt in sys.warnoptions: args.append('-W' + opt) return args def call(*popenargs, **kwargs): """Run command with arguments. Wait for command to complete, then return the returncode attribute. The arguments are the same as for the Popen constructor. Example: retcode = call(["ls", "-l"]) """ return Popen(*popenargs, **kwargs).wait() def check_call(*popenargs, **kwargs): """Run command with arguments. Wait for command to complete. If the exit code was zero then return, otherwise raise CalledProcessError. The CalledProcessError object will have the return code in the returncode attribute. The arguments are the same as for the Popen constructor. Example: check_call(["ls", "-l"]) """ retcode = call(*popenargs, **kwargs) if retcode: cmd = kwargs.get("args") if cmd is None: cmd = popenargs[0] raise CalledProcessError(retcode, cmd) return 0 def check_output(*popenargs, **kwargs): r"""Run command with arguments and return its output as a byte string. If the exit code was non-zero it raises a CalledProcessError. The CalledProcessError object will have the return code in the returncode attribute and output in the output attribute. The arguments are the same as for the Popen constructor. Example: >>> check_output(["ls", "-l", "/dev/null"]) 'crw-rw-rw- 1 root root 1, 3 Oct 18 2007 /dev/null\n' The stdout argument is not allowed as it is used internally. To capture standard error in the result, use stderr=STDOUT. >>> check_output(["/bin/sh", "-c", ... "ls -l non_existent_file ; exit 0"], ... stderr=STDOUT) 'ls: non_existent_file: No such file or directory\n' """ if 'stdout' in kwargs: raise ValueError('stdout argument not allowed, it will be overridden.') process = Popen(stdout=PIPE, *popenargs, **kwargs) output, unused_err = process.communicate() retcode = process.poll() if retcode: cmd = kwargs.get("args") if cmd is None: cmd = popenargs[0] raise CalledProcessError(retcode, cmd, output=output) return output def list2cmdline(seq): """ Translate a sequence of arguments into a command line string, using the same rules as the MS C runtime: 1) Arguments are delimited by white space, which is either a space or a tab. 2) A string surrounded by double quotation marks is interpreted as a single argument, regardless of white space contained within. A quoted string can be embedded in an argument. 3) A double quotation mark preceded by a backslash is interpreted as a literal double quotation mark. 4) Backslashes are interpreted literally, unless they immediately precede a double quotation mark. 5) If backslashes immediately precede a double quotation mark, every pair of backslashes is interpreted as a literal backslash. If the number of backslashes is odd, the last backslash escapes the next double quotation mark as described in rule 3. """ # See # http://msdn.microsoft.com/en-us/library/17w5ykft.aspx # or search http://msdn.microsoft.com for # "Parsing C++ Command-Line Arguments" result = [] needquote = False for arg in seq: bs_buf = [] # Add a space to separate this argument from the others if result: result.append(' ') needquote = (" " in arg) or ("\t" in arg) or not arg if needquote: result.append('"') for c in arg: if c == '\\': # Don't know if we need to double yet. bs_buf.append(c) elif c == '"': # Double backslashes. result.append('\\' * len(bs_buf)*2) bs_buf = [] result.append('\\"') else: # Normal char if bs_buf: result.extend(bs_buf) bs_buf = [] result.append(c) # Add remaining backslashes, if any. if bs_buf: result.extend(bs_buf) if needquote: result.extend(bs_buf) result.append('"') return ''.join(result) class Popen(object): """ Execute a child program in a new process. For a complete description of the arguments see the Python documentation. Arguments: args: A string, or a sequence of program arguments. bufsize: supplied as the buffering argument to the open() function when creating the stdin/stdout/stderr pipe file objects executable: A replacement program to execute. stdin, stdout and stderr: These specify the executed programs' standard input, standard output and standard error file handles, respectively. preexec_fn: (POSIX only) An object to be called in the child process just before the child is executed. close_fds: Controls closing or inheriting of file descriptors. shell: If true, the command will be executed through the shell. cwd: Sets the current directory before the child is executed. env: Defines the environment variables for the new process. universal_newlines: If true, use universal line endings for file objects stdin, stdout and stderr. startupinfo and creationflags (Windows only) Attributes: stdin, stdout, stderr, pid, returncode """ _child_created = False # Set here since __del__ checks it def __init__(self, args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False, startupinfo=None, creationflags=0): """Create new Popen instance.""" _cleanup() if not isinstance(bufsize, (int, long)): raise TypeError("bufsize must be an integer") if mswindows: if preexec_fn is not None: raise ValueError("preexec_fn is not supported on Windows " "platforms") if close_fds and (stdin is not None or stdout is not None or stderr is not None): raise ValueError("close_fds is not supported on Windows " "platforms if you redirect stdin/stdout/stderr") else: # POSIX if startupinfo is not None: raise ValueError("startupinfo is only supported on Windows " "platforms") if creationflags != 0: raise ValueError("creationflags is only supported on Windows " "platforms") self.stdin = None self.stdout = None self.stderr = None self.pid = None self.returncode = None self.universal_newlines = universal_newlines # Input and output objects. The general principle is like # this: # # Parent Child # ------ ----- # p2cwrite ---stdin---> p2cread # c2pread <--stdout--- c2pwrite # errread <--stderr--- errwrite # # On POSIX, the child objects are file descriptors. On # Windows, these are Windows file handles. The parent objects # are file descriptors on both platforms. The parent objects # are None when not using PIPEs. The child objects are None # when not redirecting. (p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite), to_close = self._get_handles(stdin, stdout, stderr) try: self._execute_child(args, executable, preexec_fn, close_fds, cwd, env, universal_newlines, startupinfo, creationflags, shell, to_close, p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite) except Exception: # Preserve original exception in case os.close raises. exc_type, exc_value, exc_trace = sys.exc_info() for fd in to_close: try: if mswindows: fd.Close() else: os.close(fd) except EnvironmentError: pass raise exc_type, exc_value, exc_trace if mswindows: if p2cwrite is not None: p2cwrite = msvcrt.open_osfhandle(p2cwrite.Detach(), 0) if c2pread is not None: c2pread = msvcrt.open_osfhandle(c2pread.Detach(), 0) if errread is not None: errread = msvcrt.open_osfhandle(errread.Detach(), 0) if p2cwrite is not None: self.stdin = os.fdopen(p2cwrite, 'wb', bufsize) if c2pread is not None: if universal_newlines: self.stdout = os.fdopen(c2pread, 'rU', bufsize) else: self.stdout = os.fdopen(c2pread, 'rb', bufsize) if errread is not None: if universal_newlines: self.stderr = os.fdopen(errread, 'rU', bufsize) else: self.stderr = os.fdopen(errread, 'rb', bufsize) def _translate_newlines(self, data): data = data.replace("\r\n", "\n") data = data.replace("\r", "\n") return data def __del__(self, _maxint=sys.maxint): # If __init__ hasn't had a chance to execute (e.g. if it # was passed an undeclared keyword argument), we don't # have a _child_created attribute at all. if not self._child_created: # We didn't get to successfully create a child process. return # In case the child hasn't been waited on, check if it's done. self._internal_poll(_deadstate=_maxint) if self.returncode is None and _active is not None: # Child is still running, keep us alive until we can wait on it. _active.append(self) def communicate(self, input=None): """Interact with process: Send data to stdin. Read data from stdout and stderr, until end-of-file is reached. Wait for process to terminate. The optional input argument should be a string to be sent to the child process, or None, if no data should be sent to the child. communicate() returns a tuple (stdout, stderr).""" # Optimization: If we are only using one pipe, or no pipe at # all, using select() or threads is unnecessary. if [self.stdin, self.stdout, self.stderr].count(None) >= 2: stdout = None stderr = None if self.stdin: if input: try: self.stdin.write(input) except IOError as e: if e.errno != errno.EPIPE and e.errno != errno.EINVAL: raise self.stdin.close() elif self.stdout: stdout = _eintr_retry_call(self.stdout.read) self.stdout.close() elif self.stderr: stderr = _eintr_retry_call(self.stderr.read) self.stderr.close() self.wait() return (stdout, stderr) return self._communicate(input) def poll(self): """Check if child process has terminated. Set and return returncode attribute.""" return self._internal_poll() if mswindows: # # Windows methods # def _get_handles(self, stdin, stdout, stderr): """Construct and return tuple with IO objects: p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite """ to_close = set() if stdin is None and stdout is None and stderr is None: return (None, None, None, None, None, None), to_close p2cread, p2cwrite = None, None c2pread, c2pwrite = None, None errread, errwrite = None, None if stdin is None: p2cread = _subprocess.GetStdHandle(_subprocess.STD_INPUT_HANDLE) if p2cread is None: p2cread, _ = _subprocess.CreatePipe(None, 0) elif stdin == PIPE: p2cread, p2cwrite = _subprocess.CreatePipe(None, 0) elif isinstance(stdin, (int, long)): p2cread = msvcrt.get_osfhandle(stdin) else: # Assuming file-like object p2cread = msvcrt.get_osfhandle(stdin.fileno()) p2cread = self._make_inheritable(p2cread) # We just duplicated the handle, it has to be closed at the end to_close.add(p2cread) if stdin == PIPE: to_close.add(p2cwrite) if stdout is None: c2pwrite = _subprocess.GetStdHandle(_subprocess.STD_OUTPUT_HANDLE) if c2pwrite is None: _, c2pwrite = _subprocess.CreatePipe(None, 0) elif stdout == PIPE: c2pread, c2pwrite = _subprocess.CreatePipe(None, 0) elif isinstance(stdout, (int, long)): c2pwrite = msvcrt.get_osfhandle(stdout) else: # Assuming file-like object c2pwrite = msvcrt.get_osfhandle(stdout.fileno()) c2pwrite = self._make_inheritable(c2pwrite) # We just duplicated the handle, it has to be closed at the end to_close.add(c2pwrite) if stdout == PIPE: to_close.add(c2pread) if stderr is None: errwrite = _subprocess.GetStdHandle(_subprocess.STD_ERROR_HANDLE) if errwrite is None: _, errwrite = _subprocess.CreatePipe(None, 0) elif stderr == PIPE: errread, errwrite = _subprocess.CreatePipe(None, 0) elif stderr == STDOUT: errwrite = c2pwrite elif isinstance(stderr, (int, long)): errwrite = msvcrt.get_osfhandle(stderr) else: # Assuming file-like object errwrite = msvcrt.get_osfhandle(stderr.fileno()) errwrite = self._make_inheritable(errwrite) # We just duplicated the handle, it has to be closed at the end to_close.add(errwrite) if stderr == PIPE: to_close.add(errread) return (p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite), to_close def _make_inheritable(self, handle): """Return a duplicate of handle, which is inheritable""" return _subprocess.DuplicateHandle(_subprocess.GetCurrentProcess(), handle, _subprocess.GetCurrentProcess(), 0, 1, _subprocess.DUPLICATE_SAME_ACCESS) def _find_w9xpopen(self): """Find and return absolut path to w9xpopen.exe""" w9xpopen = os.path.join( os.path.dirname(_subprocess.GetModuleFileName(0)), "w9xpopen.exe") if not os.path.exists(w9xpopen): # Eeek - file-not-found - possibly an embedding # situation - see if we can locate it in sys.exec_prefix w9xpopen = os.path.join(os.path.dirname(sys.exec_prefix), "w9xpopen.exe") if not os.path.exists(w9xpopen): raise RuntimeError("Cannot locate w9xpopen.exe, which is " "needed for Popen to work with your " "shell or platform.") return w9xpopen def _execute_child(self, args, executable, preexec_fn, close_fds, cwd, env, universal_newlines, startupinfo, creationflags, shell, to_close, p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite): """Execute program (MS Windows version)""" if not isinstance(args, types.StringTypes): args = list2cmdline(args) # Process startup details if startupinfo is None: startupinfo = STARTUPINFO() if None not in (p2cread, c2pwrite, errwrite): startupinfo.dwFlags |= _subprocess.STARTF_USESTDHANDLES startupinfo.hStdInput = p2cread startupinfo.hStdOutput = c2pwrite startupinfo.hStdError = errwrite if shell: startupinfo.dwFlags |= _subprocess.STARTF_USESHOWWINDOW startupinfo.wShowWindow = _subprocess.SW_HIDE comspec = os.environ.get("COMSPEC", "cmd.exe") args = '{} /c "{}"'.format (comspec, args) if (_subprocess.GetVersion() >= 0x80000000 or os.path.basename(comspec).lower() == "command.com"): # Win9x, or using command.com on NT. We need to # use the w9xpopen intermediate program. For more # information, see KB Q150956 # (http://web.archive.org/web/20011105084002/http://support.microsoft.com/support/kb/articles/Q150/9/56.asp) w9xpopen = self._find_w9xpopen() args = '"%s" %s' % (w9xpopen, args) # Not passing CREATE_NEW_CONSOLE has been known to # cause random failures on win9x. Specifically a # dialog: "Your program accessed mem currently in # use at xxx" and a hopeful warning about the # stability of your system. Cost is Ctrl+C wont # kill children. creationflags |= _subprocess.CREATE_NEW_CONSOLE def _close_in_parent(fd): fd.Close() to_close.remove(fd) # Start the process try: hp, ht, pid, tid = _subprocess.CreateProcess(executable, args, # no special security None, None, int(not close_fds), creationflags, env, cwd, startupinfo) except pywintypes.error, e: # Translate pywintypes.error to WindowsError, which is # a subclass of OSError. FIXME: We should really # translate errno using _sys_errlist (or similar), but # how can this be done from Python? raise WindowsError(*e.args) finally: # Child is launched. Close the parent's copy of those pipe # handles that only the child should have open. You need # to make sure that no handles to the write end of the # output pipe are maintained in this process or else the # pipe will not close when the child process exits and the # ReadFile will hang. if p2cread is not None: _close_in_parent(p2cread) if c2pwrite is not None: _close_in_parent(c2pwrite) if errwrite is not None: _close_in_parent(errwrite) # Retain the process handle, but close the thread handle self._child_created = True self._handle = hp self.pid = pid ht.Close() def _internal_poll(self, _deadstate=None, _WaitForSingleObject=_subprocess.WaitForSingleObject, _WAIT_OBJECT_0=_subprocess.WAIT_OBJECT_0, _GetExitCodeProcess=_subprocess.GetExitCodeProcess): """Check if child process has terminated. Returns returncode attribute. This method is called by __del__, so it can only refer to objects in its local scope. """ if self.returncode is None: if _WaitForSingleObject(self._handle, 0) == _WAIT_OBJECT_0: self.returncode = _GetExitCodeProcess(self._handle) return self.returncode def wait(self): """Wait for child process to terminate. Returns returncode attribute.""" if self.returncode is None: _subprocess.WaitForSingleObject(self._handle, _subprocess.INFINITE) self.returncode = _subprocess.GetExitCodeProcess(self._handle) return self.returncode def _readerthread(self, fh, buffer): buffer.append(fh.read()) def _communicate(self, input): stdout = None # Return stderr = None # Return if self.stdout: stdout = [] stdout_thread = threading.Thread(target=self._readerthread, args=(self.stdout, stdout)) stdout_thread.setDaemon(True) stdout_thread.start() if self.stderr: stderr = [] stderr_thread = threading.Thread(target=self._readerthread, args=(self.stderr, stderr)) stderr_thread.setDaemon(True) stderr_thread.start() if self.stdin: if input is not None: try: self.stdin.write(input) except IOError as e: if e.errno == errno.EPIPE: # communicate() should ignore broken pipe error pass elif e.errno == errno.EINVAL: # bpo-19612, bpo-30418: On Windows, stdin.write() # fails with EINVAL if the child process exited or # if the child process is still running but closed # the pipe. pass else: raise self.stdin.close() if self.stdout: stdout_thread.join() if self.stderr: stderr_thread.join() # All data exchanged. Translate lists into strings. if stdout is not None: stdout = stdout[0] if stderr is not None: stderr = stderr[0] # Translate newlines, if requested. We cannot let the file # object do the translation: It is based on stdio, which is # impossible to combine with select (unless forcing no # buffering). if self.universal_newlines and hasattr(file, 'newlines'): if stdout: stdout = self._translate_newlines(stdout) if stderr: stderr = self._translate_newlines(stderr) self.wait() return (stdout, stderr) def send_signal(self, sig): """Send a signal to the process """ if sig == signal.SIGTERM: self.terminate() elif sig == signal.CTRL_C_EVENT: os.kill(self.pid, signal.CTRL_C_EVENT) elif sig == signal.CTRL_BREAK_EVENT: os.kill(self.pid, signal.CTRL_BREAK_EVENT) else: raise ValueError("Unsupported signal: {}".format(sig)) def terminate(self): """Terminates the process """ try: _subprocess.TerminateProcess(self._handle, 1) except OSError as e: # ERROR_ACCESS_DENIED (winerror 5) is received when the # process already died. if e.winerror != 5: raise rc = _subprocess.GetExitCodeProcess(self._handle) if rc == _subprocess.STILL_ACTIVE: raise self.returncode = rc kill = terminate else: # # POSIX methods # def _get_handles(self, stdin, stdout, stderr): """Construct and return tuple with IO objects: p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite """ to_close = set() p2cread, p2cwrite = None, None c2pread, c2pwrite = None, None errread, errwrite = None, None if stdin is None: pass elif stdin == PIPE: p2cread, p2cwrite = self.pipe_cloexec() to_close.update((p2cread, p2cwrite)) elif isinstance(stdin, (int, long)): p2cread = stdin else: # Assuming file-like object p2cread = stdin.fileno() if stdout is None: pass elif stdout == PIPE: c2pread, c2pwrite = self.pipe_cloexec() to_close.update((c2pread, c2pwrite)) elif isinstance(stdout, (int, long)): c2pwrite = stdout else: # Assuming file-like object c2pwrite = stdout.fileno() if stderr is None: pass elif stderr == PIPE: errread, errwrite = self.pipe_cloexec() to_close.update((errread, errwrite)) elif stderr == STDOUT: if c2pwrite is not None: errwrite = c2pwrite else: # child's stdout is not set, use parent's stdout errwrite = sys.__stdout__.fileno() elif isinstance(stderr, (int, long)): errwrite = stderr else: # Assuming file-like object errwrite = stderr.fileno() return (p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite), to_close def _set_cloexec_flag(self, fd, cloexec=True): try: cloexec_flag = fcntl.FD_CLOEXEC except AttributeError: cloexec_flag = 1 old = fcntl.fcntl(fd, fcntl.F_GETFD) if cloexec: fcntl.fcntl(fd, fcntl.F_SETFD, old | cloexec_flag) else: fcntl.fcntl(fd, fcntl.F_SETFD, old & ~cloexec_flag) def pipe_cloexec(self): """Create a pipe with FDs set CLOEXEC.""" # Pipes' FDs are set CLOEXEC by default because we don't want them # to be inherited by other subprocesses: the CLOEXEC flag is removed # from the child's FDs by _dup2(), between fork() and exec(). # This is not atomic: we would need the pipe2() syscall for that. r, w = os.pipe() self._set_cloexec_flag(r) self._set_cloexec_flag(w) return r, w def _close_fds(self, but): if hasattr(os, 'closerange'): os.closerange(3, but) os.closerange(but + 1, MAXFD) else: for i in xrange(3, MAXFD): if i == but: continue try: os.close(i) except: pass # Used as a bandaid workaround for https://bugs.python.org/issue27448 # to prevent multiple simultaneous subprocess launches from interfering # with one another and leaving gc disabled. if threading: _disabling_gc_lock = threading.Lock() else: class _noop_context_manager(object): # A dummy context manager that does nothing for the rare # user of a --without-threads build. def __enter__(self): pass def __exit__(self, *args): pass _disabling_gc_lock = _noop_context_manager() def _execute_child(self, args, executable, preexec_fn, close_fds, cwd, env, universal_newlines, startupinfo, creationflags, shell, to_close, p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite): """Execute program (POSIX version)""" if isinstance(args, types.StringTypes): args = [args] else: args = list(args) if shell: args = ["/bin/sh", "-c"] + args if executable: args[0] = executable if executable is None: executable = args[0] def _close_in_parent(fd): os.close(fd) to_close.remove(fd) # For transferring possible exec failure from child to parent # The first char specifies the exception type: 0 means # OSError, 1 means some other error. errpipe_read, errpipe_write = self.pipe_cloexec() try: try: with self._disabling_gc_lock: gc_was_enabled = gc.isenabled() # Disable gc to avoid bug where gc -> file_dealloc -> # write to stderr -> hang. # https://bugs.python.org/issue1336 gc.disable() try: self.pid = os.fork() except: if gc_was_enabled: gc.enable() raise self._child_created = True if self.pid == 0: # Child try: # Close parent's pipe ends if p2cwrite is not None: os.close(p2cwrite) if c2pread is not None: os.close(c2pread) if errread is not None: os.close(errread) os.close(errpipe_read) # When duping fds, if there arises a situation # where one of the fds is either 0, 1 or 2, it # is possible that it is overwritten (#12607). if c2pwrite == 0: c2pwrite = os.dup(c2pwrite) if errwrite == 0 or errwrite == 1: errwrite = os.dup(errwrite) # Dup fds for child def _dup2(a, b): # dup2() removes the CLOEXEC flag but # we must do it ourselves if dup2() # would be a no-op (issue #10806). if a == b: self._set_cloexec_flag(a, False) elif a is not None: os.dup2(a, b) _dup2(p2cread, 0) _dup2(c2pwrite, 1) _dup2(errwrite, 2) # Close pipe fds. Make sure we don't close the # same fd more than once, or standard fds. closed = { None } for fd in [p2cread, c2pwrite, errwrite]: if fd not in closed and fd > 2: os.close(fd) closed.add(fd) if cwd is not None: os.chdir(cwd) if preexec_fn: preexec_fn() # Close all other fds, if asked for - after # preexec_fn(), which may open FDs. if close_fds: self._close_fds(but=errpipe_write) if env is None: os.execvp(executable, args) else: os.execvpe(executable, args, env) except: exc_type, exc_value, tb = sys.exc_info() # Save the traceback and attach it to the exception object exc_lines = traceback.format_exception(exc_type, exc_value, tb) exc_value.child_traceback = ''.join(exc_lines) os.write(errpipe_write, pickle.dumps(exc_value)) finally: # This exitcode won't be reported to applications, so it # really doesn't matter what we return. os._exit(255) # Parent if gc_was_enabled: gc.enable() finally: # be sure the FD is closed no matter what os.close(errpipe_write) # Wait for exec to fail or succeed; possibly raising exception data = _eintr_retry_call(os.read, errpipe_read, 1048576) pickle_bits = [] while data: pickle_bits.append(data) data = _eintr_retry_call(os.read, errpipe_read, 1048576) data = "".join(pickle_bits) finally: if p2cread is not None and p2cwrite is not None: _close_in_parent(p2cread) if c2pwrite is not None and c2pread is not None: _close_in_parent(c2pwrite) if errwrite is not None and errread is not None: _close_in_parent(errwrite) # be sure the FD is closed no matter what os.close(errpipe_read) if data != "": try: _eintr_retry_call(os.waitpid, self.pid, 0) except OSError as e: if e.errno != errno.ECHILD: raise child_exception = pickle.loads(data) raise child_exception def _handle_exitstatus(self, sts, _WIFSIGNALED=os.WIFSIGNALED, _WTERMSIG=os.WTERMSIG, _WIFEXITED=os.WIFEXITED, _WEXITSTATUS=os.WEXITSTATUS, _WIFSTOPPED=os.WIFSTOPPED, _WSTOPSIG=os.WSTOPSIG): # This method is called (indirectly) by __del__, so it cannot # refer to anything outside of its local scope. if _WIFSIGNALED(sts): self.returncode = -_WTERMSIG(sts) elif _WIFEXITED(sts): self.returncode = _WEXITSTATUS(sts) elif _WIFSTOPPED(sts): self.returncode = -_WSTOPSIG(sts) else: # Should never happen raise RuntimeError("Unknown child exit status!") def _internal_poll(self, _deadstate=None, _waitpid=os.waitpid, _WNOHANG=os.WNOHANG, _os_error=os.error, _ECHILD=errno.ECHILD): """Check if child process has terminated. Returns returncode attribute. This method is called by __del__, so it cannot reference anything outside of the local scope (nor can any methods it calls). """ if self.returncode is None: try: pid, sts = _waitpid(self.pid, _WNOHANG) if pid == self.pid: self._handle_exitstatus(sts) except _os_error as e: if _deadstate is not None: self.returncode = _deadstate if e.errno == _ECHILD: # This happens if SIGCLD is set to be ignored or # waiting for child processes has otherwise been # disabled for our process. This child is dead, we # can't get the status. # http://bugs.python.org/issue15756 self.returncode = 0 return self.returncode def wait(self): """Wait for child process to terminate. Returns returncode attribute.""" while self.returncode is None: try: pid, sts = _eintr_retry_call(os.waitpid, self.pid, 0) except OSError as e: if e.errno != errno.ECHILD: raise # This happens if SIGCLD is set to be ignored or waiting # for child processes has otherwise been disabled for our # process. This child is dead, we can't get the status. pid = self.pid sts = 0 # Check the pid and loop as waitpid has been known to return # 0 even without WNOHANG in odd situations. issue14396. if pid == self.pid: self._handle_exitstatus(sts) return self.returncode def _communicate(self, input): if self.stdin: # Flush stdio buffer. This might block, if the user has # been writing to .stdin in an uncontrolled fashion. self.stdin.flush() if not input: self.stdin.close() if _has_poll: stdout, stderr = self._communicate_with_poll(input) else: stdout, stderr = self._communicate_with_select(input) # All data exchanged. Translate lists into strings. if stdout is not None: stdout = ''.join(stdout) if stderr is not None: stderr = ''.join(stderr) # Translate newlines, if requested. We cannot let the file # object do the translation: It is based on stdio, which is # impossible to combine with select (unless forcing no # buffering). if self.universal_newlines and hasattr(file, 'newlines'): if stdout: stdout = self._translate_newlines(stdout) if stderr: stderr = self._translate_newlines(stderr) self.wait() return (stdout, stderr) def _communicate_with_poll(self, input): stdout = None # Return stderr = None # Return fd2file = {} fd2output = {} poller = select.poll() def register_and_append(file_obj, eventmask): poller.register(file_obj.fileno(), eventmask) fd2file[file_obj.fileno()] = file_obj def close_unregister_and_remove(fd): poller.unregister(fd) fd2file[fd].close() fd2file.pop(fd) if self.stdin and input: register_and_append(self.stdin, select.POLLOUT) select_POLLIN_POLLPRI = select.POLLIN | select.POLLPRI if self.stdout: register_and_append(self.stdout, select_POLLIN_POLLPRI) fd2output[self.stdout.fileno()] = stdout = [] if self.stderr: register_and_append(self.stderr, select_POLLIN_POLLPRI) fd2output[self.stderr.fileno()] = stderr = [] input_offset = 0 while fd2file: try: ready = poller.poll() except select.error, e: if e.args[0] == errno.EINTR: continue raise for fd, mode in ready: if mode & select.POLLOUT: chunk = input[input_offset : input_offset + _PIPE_BUF] try: input_offset += os.write(fd, chunk) except OSError as e: if e.errno == errno.EPIPE: close_unregister_and_remove(fd) else: raise else: if input_offset >= len(input): close_unregister_and_remove(fd) elif mode & select_POLLIN_POLLPRI: data = os.read(fd, 4096) if not data: close_unregister_and_remove(fd) fd2output[fd].append(data) else: # Ignore hang up or errors. close_unregister_and_remove(fd) return (stdout, stderr) def _communicate_with_select(self, input): read_set = [] write_set = [] stdout = None # Return stderr = None # Return if self.stdin and input: write_set.append(self.stdin) if self.stdout: read_set.append(self.stdout) stdout = [] if self.stderr: read_set.append(self.stderr) stderr = [] input_offset = 0 while read_set or write_set: try: rlist, wlist, xlist = select.select(read_set, write_set, []) except select.error, e: if e.args[0] == errno.EINTR: continue raise if self.stdin in wlist: chunk = input[input_offset : input_offset + _PIPE_BUF] try: bytes_written = os.write(self.stdin.fileno(), chunk) except OSError as e: if e.errno == errno.EPIPE: self.stdin.close() write_set.remove(self.stdin) else: raise else: input_offset += bytes_written if input_offset >= len(input): self.stdin.close() write_set.remove(self.stdin) if self.stdout in rlist: data = os.read(self.stdout.fileno(), 1024) if data == "": self.stdout.close() read_set.remove(self.stdout) stdout.append(data) if self.stderr in rlist: data = os.read(self.stderr.fileno(), 1024) if data == "": self.stderr.close() read_set.remove(self.stderr) stderr.append(data) return (stdout, stderr) def send_signal(self, sig): """Send a signal to the process """ os.kill(self.pid, sig) def terminate(self): """Terminate the process with SIGTERM """ self.send_signal(signal.SIGTERM) def kill(self): """Kill the process with SIGKILL """ self.send_signal(signal.SIGKILL) def _demo_posix(): # # Example 1: Simple redirection: Get process list # plist = Popen(["ps"], stdout=PIPE).communicate()[0] print "Process list:" print plist # # Example 2: Change uid before executing child # if os.getuid() == 0: p = Popen(["id"], preexec_fn=lambda: os.setuid(100)) p.wait() # # Example 3: Connecting several subprocesses # print "Looking for 'hda'..." p1 = Popen(["dmesg"], stdout=PIPE) p2 = Popen(["grep", "hda"], stdin=p1.stdout, stdout=PIPE) print repr(p2.communicate()[0]) # # Example 4: Catch execution error # print print "Trying a weird file..." try: print Popen(["/this/path/does/not/exist"]).communicate() except OSError, e: if e.errno == errno.ENOENT: print "The file didn't exist. I thought so..." print "Child traceback:" print e.child_traceback else: print "Error", e.errno else: print >>sys.stderr, "Gosh. No error." def _demo_windows(): # # Example 1: Connecting several subprocesses # print "Looking for 'PROMPT' in set output..." p1 = Popen("set", stdout=PIPE, shell=True) p2 = Popen('find "PROMPT"', stdin=p1.stdout, stdout=PIPE) print repr(p2.communicate()[0]) # # Example 2: Simple execution of program # print "Executing calc..." p = Popen("calc") p.wait() if __name__ == "__main__": if mswindows: _demo_windows() else: _demo_posix()
Save