Invalid flags in a RegExp literal should be an early SyntaxError
[WebKit-https.git] / JSTests / stress / arrowfunction-lexical-this-sinking-put.js
1 var newContext = {
2   id : 'new-context'
3 };
4
5 // Should be invoced by call with substitute this by newContext
6 function sink (p, q) {
7     var g = x => {
8       // Check if arrow function store context
9       if (this != newContext || this.id != newContext.id)
10           throw 'Wrong context of arrow function #1';
11
12       return x;
13     };
14     if (p) { if (q) g.inner = 42; return g; }
15     return x => {
16       // Check if arrow function store context
17       if (this != newContext || this.id != newContext.id)
18           throw 'Wrong context of arrow function #2';
19
20       return x;
21     };
22 }
23 noInline(sink);
24
25 for (var i = 0; i < 10000; ++i) {
26     var f = sink.call(newContext, true, true);// use call to substitute context
27     var result = f(42);
28     if (result != 42)
29     throw "Error: expected 42 but got " + result;
30 }
31
32 // At this point, the arrow function should be compiled down to the FTL
33
34 // Test the allocation on the implicit inner else branch
35 var f = sink.call(newContext, true, false);
36 var result = f(12);
37 if (result != 12)
38     // This shouldn't matter as it should be either correct or completely crash
39     throw "Error: expected 12 but got " + result;
40
41 // Check that the allocation did not sink beyond the property assignment
42 var f = sink.call(newContext, true, true);
43 var result = f.inner;
44 if (result != 42)
45     throw "Error: inner should be 42 but is " + result;