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.
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* This Source Code Form is subject to the terms of the Mozilla Public
3 * License, v. 2.0. If a copy of the MPL was not distributed with this
4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
6 //-----------------------------------------------------------------------------
7 var BUGNUMBER = 352885;
8 var summary = 'Do not crash iterating over gen.__proto__';
9 var actual = 'No Crash';
10 var expect = 'No Crash';
13 //-----------------------------------------------------------------------------
14 test();
15 //-----------------------------------------------------------------------------
17 function test()
18 {
19 enterFunc ('test');
20 printBugNumber(BUGNUMBER);
21 printStatus (summary);
23 function dotest()
24 {
25 var proto = (function() { yield 3; })().__proto__;
27 try {
28 proto.next();
29 throw "generatorProto.next() does not throw TypeError";
30 } catch (e) {
31 if (!(e instanceof TypeError))
32 throw "generatorProto.next() throws unexpected exception: "+uneval(e);
33 }
35 try {
36 proto.send();
37 throw "generatorProto.send() does not throw TypeError";
38 } catch (e) {
39 if (!(e instanceof TypeError))
40 throw "generatorProto.send() throws unexpected exception: "+uneval(e);
41 }
43 var obj = {};
44 try {
45 proto.throw(obj);
46 throw "generatorProto.throw(obj) does not throw TypeError";
47 } catch (e) {
48 if (!(e instanceof TypeError))
49 throw "generatorProto.throw() throws unexpected exception: "+uneval(e);
50 }
52 try {
53 proto.close();
54 throw "generatorProto.close() does not throw TypeError";
55 } catch (e) {
56 if (!(e instanceof TypeError))
57 throw "generatorProto.close() throws unexpected exception: "+uneval(e);
58 }
60 }
62 dotest();
64 reportCompare(expect, actual, summary);
66 exitFunc ('test');
67 }