blob: 86b2223be1715110e2a0cb06b548e3878423a141 [file] [log] [blame]
// 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.
info: |
|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.
negative:
phase: parse
type: SyntaxError
---*/
$DONOTEVALUATE();
let // start of a LexicalDeclaration, *not* an ASI opportunity
let;