[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@3.141.201.92: ~ $
#! /usr/bin/env python

"""
combinerefs path

A helper for analyzing PYTHONDUMPREFS output.

When the PYTHONDUMPREFS envar is set in a debug build, at Python shutdown
time Py_Finalize() prints the list of all live objects twice:  first it
prints the repr() of each object while the interpreter is still fully intact.
After cleaning up everything it can, it prints all remaining live objects
again, but the second time just prints their addresses, refcounts, and type
names (because the interpreter has been torn down, calling repr methods at
this point can get into infinite loops or blow up).

Save all this output into a file, then run this script passing the path to
that file.  The script finds both output chunks, combines them, then prints
a line of output for each object still alive at the end:

    address refcnt typename repr

address is the address of the object, in whatever format the platform C
produces for a %p format code.

refcnt is of the form

    "[" ref "]"

when the object's refcount is the same in both PYTHONDUMPREFS output blocks,
or

    "[" ref_before "->" ref_after "]"

if the refcount changed.

typename is object->ob_type->tp_name, extracted from the second PYTHONDUMPREFS
output block.

repr is repr(object), extracted from the first PYTHONDUMPREFS output block.
CAUTION:  If object is a container type, it may not actually contain all the
objects shown in the repr:  the repr was captured from the first output block,
and some of the containees may have been released since then.  For example,
it's common for the line showing the dict of interned strings to display
strings that no longer exist at the end of Py_Finalize; this can be recognized
(albeit painfully) because such containees don't have a line of their own.

The objects are listed in allocation order, with most-recently allocated
printed first, and the first object allocated printed last.


Simple examples:

    00857060 [14] str '__len__'

The str object '__len__' is alive at shutdown time, and both PYTHONDUMPREFS
output blocks said there were 14 references to it.  This is probably due to
C modules that intern the string "__len__" and keep a reference to it in a
file static.

    00857038 [46->5] tuple ()

46-5 = 41 references to the empty tuple were removed by the cleanup actions
between the times PYTHONDUMPREFS produced output.

    00858028 [1025->1456] str '<dummy key>'

The string '<dummy key>', which is used in dictobject.c to overwrite a real
key that gets deleted, grew several hundred references during cleanup.  It
suggests that stuff did get removed from dicts by cleanup, but that the dicts
themselves are staying alive for some reason. """

import re
import sys

# Generate lines from fileiter.  If whilematch is true, continue reading
# while the regexp object pat matches line.  If whilematch is false, lines
# are read so long as pat doesn't match them.  In any case, the first line
# that doesn't match pat (when whilematch is true), or that does match pat
# (when whilematch is false), is lost, and fileiter will resume at the line
# following it.
def read(fileiter, pat, whilematch):
    for line in fileiter:
        if bool(pat.match(line)) == whilematch:
            yield line
        else:
            break

def combine(fname):
    f = file(fname)
    fi = iter(f)

    for line in read(fi, re.compile(r'^Remaining objects:$'), False):
        pass

    crack = re.compile(r'([a-zA-Z\d]+) \[(\d+)\] (.*)')
    addr2rc = {}
    addr2guts = {}
    before = 0
    for line in read(fi, re.compile(r'^Remaining object addresses:$'), False):
        m = crack.match(line)
        if m:
            addr, addr2rc[addr], addr2guts[addr] = m.groups()
            before += 1
        else:
            print '??? skipped:', line

    after = 0
    for line in read(fi, crack, True):
        after += 1
        m = crack.match(line)
        assert m
        addr, rc, guts = m.groups() # guts is type name here
        if addr not in addr2rc:
            print '??? new object created while tearing down:', line.rstrip()
            continue
        print addr,
        if rc == addr2rc[addr]:
            print '[%s]' % rc,
        else:
            print '[%s->%s]' % (addr2rc[addr], rc),
        print guts, addr2guts[addr]

    f.close()
    print "%d objects before, %d after" % (before, after)

if __name__ == '__main__':
    combine(sys.argv[1])

Filemanager

Name Type Size Permission Actions
.analyze_dxp.pyo.40009 File 4.64 KB 0644
.byext.pyo.40009 File 4.42 KB 0644
.byteyears.pyo.40009 File 1.37 KB 0644
.checkappend.pyo.40009 File 4.77 KB 0644
.checkpyc.pyo.40009 File 1.93 KB 0644
.classfix.pyo.40009 File 4.09 KB 0644
.copytime.pyo.40009 File 937 B 0644
.crlf.pyo.40009 File 855 B 0644
.cvsfiles.pyo.40009 File 2.11 KB 0644
.db2pickle.pyo.40009 File 3.42 KB 0644
.diff.pyo.40009 File 2.29 KB 0644
.dutree.pyo.40009 File 2.18 KB 0644
.eptags.pyo.40009 File 1.83 KB 0644
.find_recursionlimit.pyo.40009 File 5.54 KB 0644
.finddiv.pyo.40009 File 3.22 KB 0644
.findlinksto.pyo.40009 File 1.39 KB 0644
.findnocoding.pyo.40009 File 3.03 KB 0644
.fixcid.pyo.40009 File 7.67 KB 0644
.fixheader.pyo.40009 File 1.44 KB 0644
.fixnotice.pyo.40009 File 3.42 KB 0644
.fixps.pyo.40009 File 969 B 0644
.ftpmirror.pyo.40009 File 10.81 KB 0644
.google.pyo.40009 File 792 B 0644
.gprof2html.pyo.40009 File 2.22 KB 0644
.h2py.pyo.40009 File 4.3 KB 0644
.hotshotmain.pyo.40009 File 1.82 KB 0644
.ifdef.pyo.40009 File 2.21 KB 0644
.lfcr.pyo.40009 File 880 B 0644
.linktree.pyo.40009 File 1.98 KB 0644
.lll.pyo.40009 File 947 B 0644
.logmerge.pyo.40009 File 4.96 KB 0644
.mailerdaemon.pyo.40009 File 7.19 KB 0644
.md5sum.pyo.40009 File 2.85 KB 0644
.methfix.pyo.40009 File 4.03 KB 0644
.mkreal.pyo.40009 File 1.93 KB 0644
.ndiff.pyo.40009 File 3.77 KB 0644
.nm2def.pyo.40009 File 2.89 KB 0644
.objgraph.pyo.40009 File 4.82 KB 0644
.parseentities.pyo.40009 File 2.03 KB 0644
.patchcheck.pyo.40009 File 7.24 KB 0644
.pathfix.pyo.40009 File 3.75 KB 0644
.pdeps.pyo.40009 File 3.14 KB 0644
.pickle2db.pyo.40009 File 3.73 KB 0644
.pindent.pyo.40009 File 11.3 KB 0644
.ptags.pyo.40009 File 1.37 KB 0644
.pysource.pyo.40009 File 3.92 KB 0644
.redemo.pyo.40009 File 5.16 KB 0644
.reindent-rst.pyo.40009 File 481 B 0644
.rgrep.pyo.40009 File 1.84 KB 0644
.serve.pyo.40009 File 1.56 KB 0644
.setup.pyo.40009 File 548 B 0644
.suff.pyo.40009 File 904 B 0644
.texcheck.pyo.40009 File 8.18 KB 0644
.texi2html.pyo.40009 File 81.37 KB 0644
.treesync.pyo.40009 File 5.85 KB 0644
.untabify.pyo.40009 File 1.55 KB 0644
.which.pyo.40009 File 1.59 KB 0644
.win_add2path.pyo.40009 File 2.02 KB 0644
.xxci.pyo.40009 File 3.93 KB 0644
analyze_dxp.py File 4.11 KB 0755
analyze_dxp.pyc File 4.64 KB 0644
analyze_dxp.pyo File 4.64 KB 0644
byext.py File 3.85 KB 0755
byext.pyc File 4.42 KB 0644
byext.pyo File 4.42 KB 0644
byteyears.py File 1.6 KB 0755
byteyears.pyc File 1.37 KB 0644
byteyears.pyo File 1.37 KB 0644
checkappend.py File 4.55 KB 0755
checkappend.pyc File 4.77 KB 0644
checkappend.pyo File 4.77 KB 0644
checkpyc.py File 1.96 KB 0755
checkpyc.pyc File 1.93 KB 0644
checkpyc.pyo File 1.93 KB 0644
classfix.py File 5.81 KB 0755
classfix.pyc File 4.09 KB 0644
classfix.pyo File 4.09 KB 0644
cleanfuture.py File 8.38 KB 0755
cleanfuture.pyc File 7.22 KB 0644
cleanfuture.pyo File 7.19 KB 0644
combinerefs.py File 4.28 KB 0755
combinerefs.pyc File 4.16 KB 0644
combinerefs.pyo File 4.12 KB 0644
copytime.py File 664 B 0755
copytime.pyc File 937 B 0644
copytime.pyo File 937 B 0644
crlf.py File 611 B 0755
crlf.pyc File 855 B 0644
crlf.pyo File 855 B 0644
cvsfiles.py File 1.75 KB 0755
cvsfiles.pyc File 2.11 KB 0644
cvsfiles.pyo File 2.11 KB 0644
db2pickle.py File 3.49 KB 0755
db2pickle.pyc File 3.42 KB 0644
db2pickle.pyo File 3.42 KB 0644
diff.py File 1.98 KB 0755
diff.pyc File 2.29 KB 0644
diff.pyo File 2.29 KB 0644
dutree.py File 1.58 KB 0755
dutree.pyc File 2.18 KB 0644
dutree.pyo File 2.18 KB 0644
eptags.py File 1.45 KB 0755
eptags.pyc File 1.83 KB 0644
eptags.pyo File 1.83 KB 0644
find_recursionlimit.py File 3.39 KB 0755
find_recursionlimit.pyc File 5.54 KB 0644
find_recursionlimit.pyo File 5.54 KB 0644
finddiv.py File 2.46 KB 0755
finddiv.pyc File 3.22 KB 0644
finddiv.pyo File 3.22 KB 0644
findlinksto.py File 1.04 KB 0755
findlinksto.pyc File 1.39 KB 0644
findlinksto.pyo File 1.39 KB 0644
findnocoding.py File 2.64 KB 0755
findnocoding.pyc File 3.03 KB 0644
findnocoding.pyo File 3.03 KB 0644
fixcid.py File 9.75 KB 0755
fixcid.pyc File 7.67 KB 0644
fixcid.pyo File 7.67 KB 0644
fixdiv.py File 13.57 KB 0755
fixdiv.pyc File 13.7 KB 0644
fixdiv.pyo File 13.62 KB 0644
fixheader.py File 1.16 KB 0755
fixheader.pyc File 1.44 KB 0644
fixheader.pyo File 1.44 KB 0644
fixnotice.py File 2.98 KB 0755
fixnotice.pyc File 3.42 KB 0644
fixnotice.pyo File 3.42 KB 0644
fixps.py File 894 B 0755
fixps.pyc File 969 B 0644
fixps.pyo File 969 B 0644
ftpmirror.py File 12.55 KB 0755
ftpmirror.pyc File 10.81 KB 0644
ftpmirror.pyo File 10.81 KB 0644
google.py File 520 B 0755
google.pyc File 792 B 0644
google.pyo File 792 B 0644
gprof2html.py File 2.12 KB 0755
gprof2html.pyc File 2.22 KB 0644
gprof2html.pyo File 2.22 KB 0644
h2py.py File 5.82 KB 0755
h2py.pyc File 4.3 KB 0644
h2py.pyo File 4.3 KB 0644
hotshotmain.py File 1.45 KB 0755
hotshotmain.pyc File 1.82 KB 0644
hotshotmain.pyo File 1.82 KB 0644
ifdef.py File 3.63 KB 0755
ifdef.pyc File 2.21 KB 0644
ifdef.pyo File 2.21 KB 0644
lfcr.py File 619 B 0755
lfcr.pyc File 880 B 0644
lfcr.pyo File 880 B 0644
linktree.py File 2.37 KB 0755
linktree.pyc File 1.98 KB 0644
linktree.pyo File 1.98 KB 0644
lll.py File 747 B 0755
lll.pyc File 947 B 0644
lll.pyo File 947 B 0644
logmerge.py File 5.45 KB 0755
logmerge.pyc File 4.96 KB 0644
logmerge.pyo File 4.96 KB 0644
mailerdaemon.py File 7.76 KB 0755
mailerdaemon.pyc File 7.19 KB 0644
mailerdaemon.pyo File 7.19 KB 0644
md5sum.py File 2.33 KB 0755
md5sum.pyc File 2.85 KB 0644
md5sum.pyo File 2.85 KB 0644
methfix.py File 5.33 KB 0755
methfix.pyc File 4.03 KB 0644
methfix.pyo File 4.03 KB 0644
mkreal.py File 1.59 KB 0755
mkreal.pyc File 1.93 KB 0644
mkreal.pyo File 1.93 KB 0644
ndiff.py File 3.72 KB 0755
ndiff.pyc File 3.77 KB 0644
ndiff.pyo File 3.77 KB 0644
nm2def.py File 2.39 KB 0755
nm2def.pyc File 2.89 KB 0644
nm2def.pyo File 2.89 KB 0644
objgraph.py File 5.88 KB 0755
objgraph.pyc File 4.82 KB 0644
objgraph.pyo File 4.82 KB 0644
parseentities.py File 1.68 KB 0755
parseentities.pyc File 2.03 KB 0644
parseentities.pyo File 2.03 KB 0644
patchcheck.py File 5.42 KB 0755
patchcheck.pyc File 7.24 KB 0644
patchcheck.pyo File 7.24 KB 0644
pathfix.py File 4.23 KB 0755
pathfix.pyc File 3.75 KB 0644
pathfix.pyo File 3.75 KB 0644
pdeps.py File 3.84 KB 0755
pdeps.pyc File 3.14 KB 0644
pdeps.pyo File 3.14 KB 0644
pickle2db.py File 3.85 KB 0755
pickle2db.pyc File 3.73 KB 0644
pickle2db.pyo File 3.73 KB 0644
pindent.py File 16.77 KB 0755
pindent.pyc File 11.3 KB 0644
pindent.pyo File 11.3 KB 0644
ptags.py File 1.2 KB 0755
ptags.pyc File 1.37 KB 0644
ptags.pyo File 1.37 KB 0644
pysource.py File 3.76 KB 0755
pysource.pyc File 3.92 KB 0644
pysource.pyo File 3.92 KB 0644
redemo.py File 5.66 KB 0755
redemo.pyc File 5.16 KB 0644
redemo.pyo File 5.16 KB 0644
reindent-rst.py File 278 B 0755
reindent-rst.pyc File 481 B 0644
reindent-rst.pyo File 481 B 0644
reindent.py File 10.58 KB 0755
reindent.pyc File 8.77 KB 0644
reindent.pyo File 8.74 KB 0644
rgrep.py File 1.46 KB 0755
rgrep.pyc File 1.84 KB 0644
rgrep.pyo File 1.84 KB 0644
serve.py File 1.12 KB 0755
serve.pyc File 1.56 KB 0644
serve.pyo File 1.56 KB 0644
setup.py File 421 B 0755
setup.pyc File 548 B 0644
setup.pyo File 548 B 0644
suff.py File 622 B 0755
suff.pyc File 904 B 0644
suff.pyo File 904 B 0644
svneol.py File 2.86 KB 0755
svneol.pyc File 2.83 KB 0644
svneol.pyo File 2.76 KB 0644
texcheck.py File 9.04 KB 0755
texcheck.pyc File 8.18 KB 0644
texcheck.pyo File 8.18 KB 0644
texi2html.py File 68.19 KB 0755
texi2html.pyc File 81.37 KB 0644
texi2html.pyo File 81.37 KB 0644
treesync.py File 5.65 KB 0755
treesync.pyc File 5.85 KB 0644
treesync.pyo File 5.85 KB 0644
untabify.py File 1.19 KB 0755
untabify.pyc File 1.55 KB 0644
untabify.pyo File 1.55 KB 0644
which.py File 1.59 KB 0755
which.pyc File 1.59 KB 0644
which.pyo File 1.59 KB 0644
win_add2path.py File 1.58 KB 0755
win_add2path.pyc File 2.02 KB 0644
win_add2path.pyo File 2.02 KB 0644
xxci.py File 2.73 KB 0755
xxci.pyc File 3.93 KB 0644
xxci.pyo File 3.93 KB 0644