blob: 00cbdc5edc5c89cf260d1713ec0028251e83107a [file] [log] [blame]
// Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
/// @assertion Let s1,...,sn be those try statements that are both enclosed in
/// sE and that enclose sc, and that have a finally clause. Lastly, let fj be
/// the finally clause of sj, 1 <= j <= n. Executing sc first executes f1,...,fn
/// in innermost-clause-first order. Then, if sE is a case clause, control is
/// transferred to the case clause. Otherwise, sE is necessarily a loop and
/// execution resumes after the last statement in the loop body.
/// @description Checks that the execution of "continue L;" statement transfers
/// control to the innermost enclosing 'for' statement with the appropriate
/// label and that all finally clauses between them are executed in the
/// innermost-clause-first order.
/// @author rodionov
import '../../../Utils/expect.dart';
main() {
List order = [];
L:
for (int i in [1,2,3]) {
try {
while (i < 3) {
try {
continue L;
Expect.fail("This code shouldn't be executed");
} finally {
order.add(i);
}
}
} finally {
order.add(i);
}
}
Expect.listEquals([1, 1, 2, 2, 3], order);
}