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 | // obj.hasOwnProperty(id), Object.getOwnPropertyDescriptor(obj, id), and |
michael@0 | 2 | // Object.defineProperty(obj, id, desc) do not look at obj's prototype. |
michael@0 | 3 | |
michael@0 | 4 | var angryHandler = new Proxy({}, { |
michael@0 | 5 | has: () => true, |
michael@0 | 6 | get: (t, id) => { |
michael@0 | 7 | throw new Error("angryHandler should not be queried (" + id + ")"); |
michael@0 | 8 | } |
michael@0 | 9 | }); |
michael@0 | 10 | var angryProto = new Proxy({}, angryHandler); |
michael@0 | 11 | |
michael@0 | 12 | var obj = Object.create(angryProto, { |
michael@0 | 13 | // Define hasOwnProperty directly on obj since we are poisoning its |
michael@0 | 14 | // prototype chain. |
michael@0 | 15 | hasOwnProperty: { |
michael@0 | 16 | value: Object.prototype.hasOwnProperty |
michael@0 | 17 | } |
michael@0 | 18 | }); |
michael@0 | 19 | |
michael@0 | 20 | assertEq(Object.getOwnPropertyDescriptor(obj, "foo"), undefined); |
michael@0 | 21 | assertEq(obj.hasOwnProperty("foo"), false); |
michael@0 | 22 | Object.defineProperty(obj, "foo", {value: 5}); |
michael@0 | 23 | assertEq(obj.hasOwnProperty("foo"), true); |
michael@0 | 24 | assertEq(obj.foo, 5); |