* Improve Rhino Tracer:
- Include method runtime in milliseconds. - Indent nested method calls. - Stop including method arguments in the trace output.
This commit is contained in:
		
							parent
							
								
									c6aa2b46b7
								
							
						
					
					
						commit
						9066bd1b2e
					
				
					 1 changed files with 59 additions and 21 deletions
				
			
		|  | @ -8,7 +8,7 @@ | ||||||
|  * |  * | ||||||
|  * Copyright 1998-2003 Helma Software. All Rights Reserved. |  * Copyright 1998-2003 Helma Software. All Rights Reserved. | ||||||
|  * |  * | ||||||
|  * $RCSfile$ |  * $RCSfile: Tracer.java,v $ | ||||||
|  * $Author$ |  * $Author$ | ||||||
|  * $Revision$ |  * $Revision$ | ||||||
|  * $Date$ |  * $Date$ | ||||||
|  | @ -17,12 +17,16 @@ | ||||||
| package helma.scripting.rhino.debug; | package helma.scripting.rhino.debug; | ||||||
| 
 | 
 | ||||||
| import helma.framework.ResponseTrans; | import helma.framework.ResponseTrans; | ||||||
|  | import helma.util.HtmlEncoder; | ||||||
| import org.mozilla.javascript.*; | import org.mozilla.javascript.*; | ||||||
| import org.mozilla.javascript.debug.*; | import org.mozilla.javascript.debug.*; | ||||||
|  | import java.util.Stack; | ||||||
|  | import java.util.ArrayList; | ||||||
| 
 | 
 | ||||||
| public class Tracer implements Debugger { | public class Tracer implements Debugger { | ||||||
| 
 | 
 | ||||||
|     ResponseTrans res; |     ResponseTrans res; | ||||||
|  |     TracerFrame frame = null; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      *  Create a tracer that writes to this response object |      *  Create a tracer that writes to this response object | ||||||
|  | @ -37,11 +41,12 @@ public class Tracer implements Debugger { | ||||||
|     public void handleCompilationDone(Context cx, DebuggableScript script, String source) {} |     public void handleCompilationDone(Context cx, DebuggableScript script, String source) {} | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      *  Implementws getFrame in interface org.mozilla.javascript.debug.Debugger |      *  Implements getFrame() in interface org.mozilla.javascript.debug.Debugger | ||||||
|      */ |      */ | ||||||
|     public DebugFrame getFrame(Context cx, DebuggableScript script) { |     public DebugFrame getFrame(Context cx, DebuggableScript script) { | ||||||
|         if (script.isFunction()) { |         if (script.isFunction()) { | ||||||
|             return new TracerFrame(script); |             frame = new TracerFrame(script, frame); | ||||||
|  |             return frame; | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
|  | @ -61,10 +66,19 @@ public class Tracer implements Debugger { | ||||||
| 
 | 
 | ||||||
|     class TracerFrame implements DebugFrame { |     class TracerFrame implements DebugFrame { | ||||||
| 
 | 
 | ||||||
|  |         TracerFrame parent; | ||||||
|  |         ArrayList children = new ArrayList(); | ||||||
|         DebuggableScript script; |         DebuggableScript script; | ||||||
|  |         int currentLine, depth = 0; | ||||||
|  |         long time; | ||||||
| 
 | 
 | ||||||
|         TracerFrame(DebuggableScript script) { |         TracerFrame(DebuggableScript script, TracerFrame parent) { | ||||||
|             this.script = script; |             this.script = script; | ||||||
|  |             this.parent = parent; | ||||||
|  |             if (parent != null) { | ||||||
|  |                 parent.children.add(this); | ||||||
|  |                 depth = parent.depth + 1; | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /** |         /** | ||||||
|  | @ -74,20 +88,7 @@ public class Tracer implements Debugger { | ||||||
|         public void onEnter(Context cx, Scriptable activation,  |         public void onEnter(Context cx, Scriptable activation,  | ||||||
|                             Scriptable thisObj, Object[] args) { |                             Scriptable thisObj, Object[] args) { | ||||||
| 
 | 
 | ||||||
|             StringBuffer b = new StringBuffer("Trace: "); |             time = System.currentTimeMillis(); | ||||||
|             b.append(Tracer.toString(script)); |  | ||||||
|             b.append("("); |  | ||||||
| 
 |  | ||||||
|             for (int i = 0; i < args.length; i++) { |  | ||||||
|                 b.append(args[i]); |  | ||||||
| 
 |  | ||||||
|                 if (i < args.length - 1) { |  | ||||||
|                     b.append(", "); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             b.append(")"); |  | ||||||
|             res.debug(b.toString()); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /** |         /** | ||||||
|  | @ -100,13 +101,50 @@ public class Tracer implements Debugger { | ||||||
|         /** |         /** | ||||||
|          *  Called when the function or script for this frame is about to return. |          *  Called when the function or script for this frame is about to return. | ||||||
|          */ |          */ | ||||||
|         public void onExit(Context cx, boolean byThrow, Object resultOrException) {} |         public void onExit(Context cx, boolean byThrow, Object resultOrException) { | ||||||
|  |             time = System.currentTimeMillis() - time; | ||||||
|  |             frame = parent; | ||||||
|  |             if (parent == null) | ||||||
|  |                 render(); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         /** |         /** | ||||||
|          *  Called when executed code reaches new line in the source. |          *  Called when executed code reaches new line in the source. | ||||||
|          */ |          */ | ||||||
|         public void onLineChange(Context cx, int lineNumber) {} |         public void onLineChange(Context cx, int lineNumber) { | ||||||
|  |             currentLine = lineNumber; | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|  |         public void render() { | ||||||
|  |             // Simplify Trace by dropping fast invocations. May be useful when looking | ||||||
|  |             // looking for bottlenecks, but not when trying to find out wtf is going on | ||||||
|  |             // if (time <= 1) | ||||||
|  |             //     return;             | ||||||
|  |             StringBuffer b = new StringBuffer("Trace: "); | ||||||
|  |             for (int i = 0; i < depth; i++) | ||||||
|  |                 b.append(". "); | ||||||
|  |             b.append(Tracer.toString(script)); | ||||||
|  |             b.append("("); | ||||||
|  | 
 | ||||||
|  |             /* for (int i = 0; i < args.length; i++) { | ||||||
|  |                b.append(HtmlEncoder.encodeAll(ScriptRuntime.toString(args[i]))); | ||||||
|  | 
 | ||||||
|  |                if (i < args.length - 1) { | ||||||
|  |                    b.append(", "); | ||||||
|  |                } | ||||||
|  |            } */ | ||||||
|  | 
 | ||||||
|  |             b.append(")"); | ||||||
|  | 
 | ||||||
|  |             b.append(" <b>"); | ||||||
|  |             b.append(time); | ||||||
|  |             b.append(" millis</b>"); | ||||||
|  | 
 | ||||||
|  |             res.debug(b); | ||||||
|  | 
 | ||||||
|  |             for (int i = 0; i < children.size(); i++) | ||||||
|  |                 ((TracerFrame) children.get(i)).render(); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue