// Copyright 2015 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. Debug = debug.Debug var exception = null; var log = []; function listener(event, exec_state, event_data, data) { if (event != Debug.DebugEvent.Break) return; try { print(event_data.sourceLineText()); var entry = ""; for (var i = 0; i < exec_state.frameCount(); i++) { entry += exec_state.frame(i).sourceLineText().substr(-1); entry += exec_state.frame(i).sourceColumn(); } log.push(entry); exec_state.prepareStep(Debug.StepAction.StepIn); } catch (e) { exception = e; } }; function u(x) { return x.toUpperCase(); // d } // e var n = 3; var o = { toString: function() { return "D"; // f } // g } Debug.setListener(listener); debugger; // a var s = `1 ${u("a")} 2 ${u("b")} 3 ${n} 4 ${o}`; // b Debug.setListener(null); // c assertNull(exception); assertEquals([ "a0", "b8", "d11b13", "d25b13", "b25", "d11b25", "d25b25", "f4b44", "f15b44", "c0" ], log);