js/src/jit-test/tests/debug/breakpoint-multi-03.js

Sat, 03 Jan 2015 20:18:00 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Sat, 03 Jan 2015 20:18:00 +0100
branch
TOR_BUG_3246
changeset 7
129ffea94266
permissions
-rw-r--r--

Conditionally enable double key logic according to:
private browsing mode or privacy.thirdparty.isolate preference and
implement in GetCookieStringCommon and FindCookie where it counts...
With some reservations of how to convince FindCookie users to test
condition and pass a nullptr when disabling double key logic.

michael@0 1 // Multiple Debugger objects can set breakpoints at the same instruction.
michael@0 2
michael@0 3 var g = newGlobal();
michael@0 4 function attach(g, i) {
michael@0 5 var dbg = Debugger(g);
michael@0 6 dbg.onDebuggerStatement = function (frame) {
michael@0 7 var s = frame.eval("f").return.script;
michael@0 8 var offs = s.getLineOffsets(g.line0 + 3);
michael@0 9 for (var j = 0; j < offs.length; j++)
michael@0 10 s.setBreakpoint(offs[j], {hit: function () { g.log += "" + i; }});
michael@0 11 };
michael@0 12 }
michael@0 13
michael@0 14 g.eval("var line0 = Error().lineNumber;\n" +
michael@0 15 "function f() {\n" + // line0 + 1
michael@0 16 " log += 'a';\n" + // line0 + 2
michael@0 17 " log += 'b';\n" + // line0 + 3
michael@0 18 "}\n");
michael@0 19
michael@0 20 for (var i = 0; i < 3; i++)
michael@0 21 attach(g, i);
michael@0 22
michael@0 23 g.log = '';
michael@0 24 g.eval('debugger;');
michael@0 25 g.log += 'x';
michael@0 26 g.f();
michael@0 27 assertEq(g.log, 'xa012b');

mercurial