080fa87143
The target of a 'break' statement without a provided label must be a regular block belonging to a surrounding loop or switch statement, named blocks (i.e. the one that just define a label) on the other hand must be targeted specifically with the provided label (and not implicitly). This fixes the behavior by introducing a dedicated {BlockKind::kNamed} for this purpose. R=clemensh@chromium.org TEST=mjsunit/regress/regress-9022 BUG=v8:9022 Change-Id: I94c3d5b1196ed94b8b1b31f6eb3b68070cf324e8 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1538126 Commit-Queue: Michael Starzinger <mstarzinger@chromium.org> Reviewed-by: Clemens Hammacher <clemensh@chromium.org> Cr-Commit-Position: refs/heads/master@{#60445}
31 lines
587 B
JavaScript
31 lines
587 B
JavaScript
// Copyright 2019 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --validate-asm --allow-natives-syntax
|
|
|
|
function Module(stdlib, ffi) {
|
|
"use asm";
|
|
var log = ffi.log;
|
|
function boom() {
|
|
while (1) {
|
|
label: {
|
|
break;
|
|
}
|
|
log(1);
|
|
break;
|
|
}
|
|
log(2);
|
|
}
|
|
return { boom: boom }
|
|
}
|
|
|
|
var log_value = 0;
|
|
function log(i) {
|
|
log_value += i;
|
|
}
|
|
|
|
Module({}, { log: log }).boom();
|
|
assertTrue(%IsAsmWasmCode(Module));
|
|
assertEquals(2, log_value);
|