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 | // |reftest| skip-if(!xulRuntime.shell) |
michael@0 | 2 | // bug 905774 |
michael@0 | 3 | |
michael@0 | 4 | // Proxy options |
michael@0 | 5 | var opts = new Proxy({loc: false}, {}); |
michael@0 | 6 | assertEq(Reflect.parse("0;", opts).loc === null, true); |
michael@0 | 7 | opts.loc = true; |
michael@0 | 8 | assertEq(Reflect.parse("0;", opts).loc !== null, true); |
michael@0 | 9 | delete opts.loc; |
michael@0 | 10 | assertEq(Reflect.parse("0;", opts).loc !== null, true); // default is true |
michael@0 | 11 | |
michael@0 | 12 | // Proxy builder |
michael@0 | 13 | var builder = { |
michael@0 | 14 | program: function (body) { return body.join(); }, |
michael@0 | 15 | expressionStatement: function (expr) { return expr + ";" }, |
michael@0 | 16 | literal: function (val) { return "" + val; } |
michael@0 | 17 | }; |
michael@0 | 18 | opts = {builder: new Proxy(builder, {})}; |
michael@0 | 19 | assertEq(Reflect.parse("0xff;", opts), "255;"); |
michael@0 | 20 | |
michael@0 | 21 | reportCompare(0, 0, 'ok'); |