mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 07:31:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
#! /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()
 |