// 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: --use-osr

function foo(a) {
  var sum = 0;
  var inc = a ? 100 : 200;
  for (var i = 0; i < 100000; i++) {
    sum += inc;
  }
  return sum + inc;
}

function bar(a) {
  var sum = 0;
  var inc = a ? 100 : 200;
  var x = a ? 5 : 6;
  var y = a ? 7 : 8;
  for (var i = 0; i < 100000; i++) {
    sum += inc;
  }
  return sum ? x : y;
}

function baz(a) {
  var limit = a ? 100001 : 100002;
  var r = 1;
  var x = a ? 1 : 2;
  var y = a ? 3 : 4;
  for (var i = 0; i < limit; i++) {
    r = r * -1;
  }
  return r > 0 ? x == y : x != y;
}

function qux(a) {
  var limit = a ? 100001 : 100002;
  var r = 1;
  var x = a ? 1 : 2;
  var y = a ? 3 : 4;
  for (var i = 0; i < limit; i++) {
    r = r * -1;
  }
  var w = r > 0 ? x : y;
  var z = r > 0 ? y : x;
  return w === z;
}

function test(func, tv, fv) {
  assertEquals(tv, func(true));
  assertEquals(fv, func(false));
  assertEquals(tv, func(true));
  assertEquals(fv, func(false));
}

test(foo, 10000100, 20000200);
test(bar, 5, 6);
test(baz, true, false);
test(qux, false, false);