2015-12-17 23:11:46 +01:00
|
|
|
// Copyright (C) 2015 Mozilla Corporation. All rights reserved.
|
|
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
|
|
|
|
/*---
|
|
|
|
author: Jeff Walden
|
|
|
|
es6id: 13.3.1.1
|
|
|
|
description: >
|
|
|
|
let: |let let| split across two lines is not subject to automatic semicolon insertion.
|
2018-01-05 18:26:51 +01:00
|
|
|
info: |
|
2015-12-17 23:11:46 +01:00
|
|
|
|let| followed by a name is a lexical declaration. This is so even if the
|
|
|
|
name is on a new line. ASI applies *only* if an offending token not allowed
|
|
|
|
by the grammar is encountered, and there's no [no LineTerminator here]
|
|
|
|
restriction in LexicalDeclaration or ForDeclaration forbidding a line break.
|
|
|
|
|
|
|
|
It's a tricky point, but this is true *even if* the name is "let", a name that
|
|
|
|
can't be bound by LexicalDeclaration or ForDeclaration. Per 5.3, static
|
|
|
|
semantics early errors are validated *after* determining productions matching
|
|
|
|
the source text.
|
|
|
|
|
|
|
|
So in this testcase, the eval text matches LexicalDeclaration. No ASI occurs,
|
|
|
|
because "let\nlet = ..." matches LexicalDeclaration before static semantics
|
|
|
|
are considered. *Then* 13.3.1.1's static semantics for the LexicalDeclaration
|
|
|
|
just chosen, per 5.3, are validated to recognize the Script as invalid. Thus
|
|
|
|
the eval script can't be evaluated, and a SyntaxError is thrown.
|
2016-01-31 00:57:28 +01:00
|
|
|
negative:
|
2017-12-03 06:06:42 +01:00
|
|
|
phase: parse
|
2016-01-31 00:57:28 +01:00
|
|
|
type: SyntaxError
|
2015-12-17 23:11:46 +01:00
|
|
|
---*/
|
|
|
|
|
2018-10-11 16:59:24 +02:00
|
|
|
$DONOTEVALUATE();
|
2017-04-29 22:31:08 +02:00
|
|
|
|
2015-12-17 23:11:46 +01:00
|
|
|
let // start of a LexicalDeclaration, *not* an ASI opportunity
|
|
|
|
let = "irrelevant initializer";
|