• adamk's avatar
    [async functions] Disallow 'await' in arrow params inside async functions · 232a3360
    adamk authored
    The following code was previously accepted:
    
      async function f() {
        let g = (await) => {};
      }
    
    But per the spec, using 'await' is disallowed in arrow parameters
    by an early error rule (just as 'yield' is disallowed in arrow
    params inside generators).
    
    There was special logic in ParseUnaryExpression which seems to have been
    there only to allow that case. Having removed it, we get a SyntaxError in
    the right cases anyway when ParseUnaryExpression chokes on whatever
    illegal token follows 'await' in the cases this code previously handled.
    
    Also removes the unnecessary AsyncBindingPatternProduction enum value.
    
    R=caitp@igalia.com, littledan@chromium.org
    BUG=v8:4483
    
    Review-Url: https://codereview.chromium.org/2258313002
    Cr-Commit-Position: refs/heads/master@{#38802}
    232a3360
Name
Last commit
Last update
..
OWNERS Loading commit data...
expression-classifier.h Loading commit data...
func-name-inferrer.cc Loading commit data...
func-name-inferrer.h Loading commit data...
parameter-initializer-rewriter.cc Loading commit data...
parameter-initializer-rewriter.h Loading commit data...
parse-info.cc Loading commit data...
parse-info.h Loading commit data...
parser-base.h Loading commit data...
parser.cc Loading commit data...
parser.h Loading commit data...
pattern-rewriter.cc Loading commit data...
preparse-data-format.h Loading commit data...
preparse-data.cc Loading commit data...
preparse-data.h Loading commit data...
preparser.cc Loading commit data...
preparser.h Loading commit data...
rewriter.cc Loading commit data...
rewriter.h Loading commit data...
scanner-character-streams.cc Loading commit data...
scanner-character-streams.h Loading commit data...
scanner.cc Loading commit data...
scanner.h Loading commit data...
token.cc Loading commit data...
token.h Loading commit data...