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 -*- */
3 /*
4 * Any copyright is dedicated to the Public Domain.
5 * http://creativecommons.org/licenses/publicdomain/
6 */
8 /*
9 * In strict mode, the identifier bound by a 'catch' clause may not
10 * be 'eval' or 'arguments'.
11 */
12 assertEq(testLenientAndStrict('try{}catch(eval){}',
13 parsesSuccessfully,
14 parseRaisesException(SyntaxError)),
15 true);
16 assertEq(testLenientAndStrict('try{}catch([eval]){}',
17 parsesSuccessfully,
18 parseRaisesException(SyntaxError)),
19 true);
20 assertEq(testLenientAndStrict('try{}catch({x:eval}){}',
21 parsesSuccessfully,
22 parseRaisesException(SyntaxError)),
23 true);
24 assertEq(testLenientAndStrict('try{}catch(arguments){}',
25 parsesSuccessfully,
26 parseRaisesException(SyntaxError)),
27 true);
28 assertEq(testLenientAndStrict('try{}catch([arguments]){}',
29 parsesSuccessfully,
30 parseRaisesException(SyntaxError)),
31 true);
32 assertEq(testLenientAndStrict('try{}catch({x:arguments}){}',
33 parsesSuccessfully,
34 parseRaisesException(SyntaxError)),
35 true);
37 reportCompare(true, true);