// Copyright 2015 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: --allow-natives-syntax --use-osr "use strict"; function test(expected, func) { %PrepareFunctionForOptimization(func); assertEquals(expected, func()); %PrepareFunctionForOptimization(func); assertEquals(expected, func()); %PrepareFunctionForOptimization(func); assertEquals(expected, func()); } function bar() { var result; { let sum = 0; for (let i = 0; i < 90; i++) { sum += i; if (i == 45) %OptimizeOsr(); } result = sum; } return result; } %PrepareFunctionForOptimization(bar); test(4005, bar); function baz() { let sum = 0; for (let i = 0; i < 2; i++) { %PrepareFunctionForOptimization(baz); sum = 2; %OptimizeOsr(); } return sum; } test(2, baz); function qux() { var result = 0; for (let i = 0; i < 2; i++) { %PrepareFunctionForOptimization(qux); result = i; %OptimizeOsr(); } return result; } test(1, qux); function nux() { var result = 0; for (let i = 0; i < 2; i++) { { %PrepareFunctionForOptimization(nux); let sum = i; %OptimizeOsr(); result = sum; } } return result; } test(1, nux); function blo() { var result; { let sum = 0; for (let i = 0; i < 90; i++) { sum += i; if (i == 45) %OptimizeOsr(); } result = ret; function ret() { return sum; } } return result; } %PrepareFunctionForOptimization(blo); test(4005, blo());