keith_miller@apple.com | bcc77f2 | 2016-07-15 06:03:25 +0000 | [diff] [blame] | 1 | // This file was procedurally generated from the following sources: |
| 2 | // - src/annex-b-fns/func-skip-param.case |
| 3 | // - src/annex-b-fns/func/block.template |
| 4 | /*--- |
| 5 | description: Extension not observed when there is a formal parameter with the same name (Block statement in function scope containing a function declaration) |
| 6 | esid: sec-web-compat-functiondeclarationinstantiation |
| 7 | es6id: B.3.3.1 |
| 8 | flags: [generated, noStrict] |
| 9 | info: | |
| 10 | B.3.3.1 Changes to FunctionDeclarationInstantiation |
| 11 | |
| 12 | [...] |
| 13 | ii. If replacing the FunctionDeclaration f with a VariableStatement that |
| 14 | has F as a BindingIdentifier would not produce any Early Errors for |
| 15 | func and F is not an element of BoundNames of argumentsList, then |
| 16 | [...] |
| 17 | ---*/ |
| 18 | var init, after; |
| 19 | |
| 20 | (function(f) { |
| 21 | init = f; |
| 22 | |
| 23 | { |
| 24 | function f() { } |
| 25 | } |
| 26 | |
| 27 | after = f; |
| 28 | }(123)); |
| 29 | |
| 30 | assert.sameValue(init, 123, 'binding is not initialized to `undefined`'); |
| 31 | assert.sameValue(after, 123, 'value is not updated following evaluation'); |