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 | // evalWithBindings ignores non-enumerable and non-own properties. |
michael@0 | 2 | var g = newGlobal(); |
michael@0 | 3 | var dbg = new Debugger(g); |
michael@0 | 4 | var hits = 0; |
michael@0 | 5 | dbg.onDebuggerStatement = function (frame) { |
michael@0 | 6 | assertEq(frame.evalWithBindings("toString + constructor + length", []).return, 112233); |
michael@0 | 7 | var obj = Object.create({constructor: "FAIL"}, {length: {value: "fail"}}); |
michael@0 | 8 | assertEq(frame.evalWithBindings("toString + constructor + length", obj).return, 112233); |
michael@0 | 9 | hits++; |
michael@0 | 10 | }; |
michael@0 | 11 | g.eval("function f() { var toString = 111111, constructor = 1111, length = 11; debugger; }"); |
michael@0 | 12 | g.f(); |
michael@0 | 13 | assertEq(hits, 1); |