Sat, 03 Jan 2015 20:18:00 +0100
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 | var g = newGlobal(); |
michael@0 | 2 | var dbg = new Debugger(g); |
michael@0 | 3 | |
michael@0 | 4 | g.eval("function h() { debugger; }"); |
michael@0 | 5 | g.eval("function g() { h() }"); |
michael@0 | 6 | g.eval("function f() { var blah = 333; g() }"); |
michael@0 | 7 | |
michael@0 | 8 | dbg.onDebuggerStatement = function(frame) { |
michael@0 | 9 | frame = frame.older; |
michael@0 | 10 | g.trace = frame.older.eval("(new Error()).stack;").return; |
michael@0 | 11 | } |
michael@0 | 12 | g.f(); |
michael@0 | 13 | |
michael@0 | 14 | assertEq(typeof g.trace, "string"); |
michael@0 | 15 | |
michael@0 | 16 | var frames = g.trace.split("\n"); |
michael@0 | 17 | assertEq(frames[0].contains("eval code"), true); |
michael@0 | 18 | assertEq(frames[1].startsWith("f@"), true); |
michael@0 | 19 | assertEq(frames[2].startsWith("@"), true); |