Commits

Konstantin Lopuhin committed ec5611a

jit and op capture ratio

Comments (0)

Files changed (2)

_jitviewer/app.py

             func.count = getattr(loop, 'count', '?')
             func.descr = mangle_descr(loop.descr)
             func.statprof_ratio = getattr(loop, 'statprof_ratio', '?')
+            func.op_capture_ratio = getattr(loop, 'op_capture_ratio', '?')
             loops.append(func)
-        loops.sort(lambda a, b: cmp(b.count, a.count))
+        loops.sort(key=lambda l: l.statprof_ratio)
+        loops.reverse()
         if len(loops) > CUTOFF:
             extra_data = "Show all (%d) loops" % len(loops)
         else:
 
         qt_workaround = ('Qt/4.7.2' in flask.request.user_agent.string)
         return flask.render_template('index.html', loops=loops,
+                                     jit_ratio=self.storage.jit_ratio,
                                      filename=self.filename,
                                      qt_workaround=qt_workaround,
                                      extra_data=extra_data)
     statprof_filename = os.path.join(
             os.path.dirname(filename), 'statprof.log')
     if os.path.exists(statprof_filename):
-        parse_statprof_log(statprof_filename, loops) 
+        jit_ratio = parse_statprof_log(statprof_filename, loops) 
         for loop in loops:
-            print loop, loop.statprof_ratio
-        #exit() #import pdb; pdb.set_trace()
+            print loop.statprof_ratio
 
     parse_log_counts(extract_category(log, 'jit-backend-count'), loops)
     storage.loops = [loop for loop in loops
                      if not loop.descr.startswith('bridge')]
     storage.loop_dict = create_loop_dict(loops)
+    storage.jit_ratio = jit_ratio
     app = OverrideFlask('_jitviewer')
     server = Server(filename, storage)
     app.debug = True

_jitviewer/templates/index.html

   <div>
   <div id="loops">
     <ul>
+      <li>{{jit_ratio}}</li>
       {% for item in loops %}
-      <li class="loopitem" id="{{item.descr}}" name="{{item.repr()}}"><span><a href="/" onClick="show_loop('{{item.descr}}'); return false">{{item.repr()}}</a> run {{item.count}} times, {{item.statprof_ratio}}</span></li>
+      <li class="loopitem" id="{{item.descr}}" name="{{item.repr()}}"><span><a href="/" onClick="show_loop('{{item.descr}}'); return false">{{item.repr()}}</a> run {{item.count}} times, {{item.statprof_ratio}}, op capture ratio {{item.op_capture_ratio}}</span></li>
       {% endfor %}
     </ul>
     {% if extra_data %}
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.