diff options
| author | Victor Stinner <vstinner@python.org> | 2022-10-11 10:07:57 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-10-11 10:07:57 +0200 | 
| commit | e0ae9ddffe0a708d0d3f5b8cc10488d466fc43c4 (patch) | |
| tree | bc97c042724b8c89a29d36f81b1f804070622784 /Tools/scripts/gprof2html.py | |
| parent | b399115ef18945f7526492225d72a512048ad20d (diff) | |
| download | cpython-git-e0ae9ddffe0a708d0d3f5b8cc10488d466fc43c4.tar.gz | |
gh-97669: Remove outdated example scripts (#97675) (#98167)
Remove outdated example scripts of the Tools/scripts/ directory:
* gprof2html.py
* md5sum.py
* nm2def.py
* pathfix.py
* win_add2path.py
Remove test_gprof2html, test_md5sum and test_pathfix of test_tools.
Diffstat (limited to 'Tools/scripts/gprof2html.py')
| -rwxr-xr-x | Tools/scripts/gprof2html.py | 87 | 
1 files changed, 0 insertions, 87 deletions
| diff --git a/Tools/scripts/gprof2html.py b/Tools/scripts/gprof2html.py deleted file mode 100755 index bf0530ef3e..0000000000 --- a/Tools/scripts/gprof2html.py +++ /dev/null @@ -1,87 +0,0 @@ -#! /usr/bin/env python3 - -"""Transform gprof(1) output into useful HTML.""" - -import html -import os -import re -import sys -import webbrowser - -header = """\ -<html> -<head> -  <title>gprof output (%s)</title> -</head> -<body> -<pre> -""" - -trailer = """\ -</pre> -</body> -</html> -""" - -def add_escapes(filename): -    with open(filename, encoding="utf-8") as fp: -        for line in fp: -            yield html.escape(line) - -def gprof2html(input, output, filename): -    output.write(header % filename) -    for line in input: -        output.write(line) -        if line.startswith(" time"): -            break -    labels = {} -    for line in input: -        m = re.match(r"(.*  )(\w+)\n", line) -        if not m: -            output.write(line) -            break -        stuff, fname = m.group(1, 2) -        labels[fname] = fname -        output.write('%s<a name="flat:%s" href="#call:%s">%s</a>\n' % -                     (stuff, fname, fname, fname)) -    for line in input: -        output.write(line) -        if line.startswith("index % time"): -            break -    for line in input: -        m = re.match(r"(.*  )(\w+)(( <cycle.*>)? \[\d+\])\n", line) -        if not m: -            output.write(line) -            if line.startswith("Index by function name"): -                break -            continue -        prefix, fname, suffix = m.group(1, 2, 3) -        if fname not in labels: -            output.write(line) -            continue -        if line.startswith("["): -            output.write('%s<a name="call:%s" href="#flat:%s">%s</a>%s\n' % -                         (prefix, fname, fname, fname, suffix)) -        else: -            output.write('%s<a href="#call:%s">%s</a>%s\n' % -                         (prefix, fname, fname, suffix)) -    for line in input: -        for part in re.findall(r"(\w+(?:\.c)?|\W+)", line): -            if part in labels: -                part = '<a href="#call:%s">%s</a>' % (part, part) -            output.write(part) -    output.write(trailer) - - -def main(): -    filename = "gprof.out" -    if sys.argv[1:]: -        filename = sys.argv[1] -    outputfilename = filename + ".html" -    input = add_escapes(filename) -    with open(outputfilename, "w", encoding="utf-8") as output: -        gprof2html(input, output, filename) -    webbrowser.open("file:" + os.path.abspath(outputfilename)) - -if __name__ == '__main__': -    main() | 
