|
|
|
// Copyright 2010 the V8 project authors. All rights reserved.
|
|
|
|
// Redistribution and use in source and binary forms, with or without
|
|
|
|
// modification, are permitted provided that the following conditions are
|
|
|
|
// met:
|
|
|
|
//
|
|
|
|
// * Redistributions of source code must retain the above copyright
|
|
|
|
// notice, this list of conditions and the following disclaimer.
|
|
|
|
// * Redistributions in binary form must reproduce the above
|
|
|
|
// copyright notice, this list of conditions and the following
|
|
|
|
// disclaimer in the documentation and/or other materials provided
|
|
|
|
// with the distribution.
|
|
|
|
// * Neither the name of Google Inc. nor the names of its
|
|
|
|
// contributors may be used to endorse or promote products derived
|
|
|
|
// from this software without specific prior written permission.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
function Test() {
|
|
|
|
this.result = 0;
|
|
|
|
this.x = 0;
|
|
|
|
this.y = 0;
|
|
|
|
this.z = 0;
|
|
|
|
}
|
|
|
|
var a = 1;
|
|
|
|
var b = 2;
|
|
|
|
var c = 4;
|
|
|
|
var d = 8;
|
|
|
|
|
|
|
|
// Test operations expected to stay on the fast path. Enumerate all binary
|
|
|
|
// trees with <= 4 leaves.
|
|
|
|
Test.prototype.test0 = function () {
|
|
|
|
this.result = a | b;
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test1 = function() {
|
|
|
|
this.result = (a | b) | c;
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test2 = function() {
|
|
|
|
this.result = a | (b | c);
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test3 = function() {
|
|
|
|
this.result = ((a | b) | c) | d;
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test4 = function() {
|
|
|
|
this.result = (a | (b | c)) | d;
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test5 = function() {
|
|
|
|
this.result = (a | b) | (c | d);
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test6 = function() {
|
|
|
|
this.result = a | ((b | c) | d);
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test7 = function() {
|
|
|
|
this.result = a | (b | (c | d));
|
|
|
|
};
|
|
|
|
|
|
|
|
// These tests should fail if we bailed out to the beginning of the full
|
|
|
|
// code.
|
|
|
|
Test.prototype.test8 = function () {
|
|
|
|
// If this.x = 1 and a = 1.1:
|
|
|
|
this.y = this.x | b; // Should be (1 | 2) == 3.
|
|
|
|
this.x = c; // Should be 4.
|
|
|
|
this.z = this.x | a; // Should be (4 | 1.1) == 5.
|
|
|
|
};
|
|
|
|
|
|
|
|
Test.prototype.test9 = function() {
|
|
|
|
// If this.x = 2 and a = 1.1:
|
|
|
|
this.z = // (14 | 1.1) == 15
|
|
|
|
(this.x = // (6 | 8) == 14
|
|
|
|
(this.y = // (2 | 4) == 6
|
|
|
|
this.x // 2
|
|
|
|
| c) // 4
|
|
|
|
| d) // 8
|
|
|
|
| a; // 1.1
|
|
|
|
}
|
|
|
|
|
|
|
|
Test.prototype.test10 = function() {
|
|
|
|
this.z = (a >> b) | (c >> c);
|
|
|
|
}
|
|
|
|
|
|
|
|
Test.prototype.test11 = function(x) {
|
|
|
|
this.z = x >> x;
|
|
|
|
}
|
|
|
|
|
|
|
|
var t = new Test();
|
|
|
|
|
|
|
|
t.test0();
|
|
|
|
assertEquals(3, t.result);
|
|
|
|
|
|
|
|
t.test1();
|
|
|
|
assertEquals(7, t.result);
|
|
|
|
t.test2();
|
|
|
|
assertEquals(7, t.result);
|
|
|
|
|
|
|
|
t.test3();
|
|
|
|
assertEquals(15, t.result);
|
|
|
|
t.test4();
|
|
|
|
assertEquals(15, t.result);
|
|
|
|
t.test5();
|
|
|
|
assertEquals(15, t.result);
|
|
|
|
t.test6();
|
|
|
|
assertEquals(15, t.result);
|
|
|
|
t.test7();
|
|
|
|
assertEquals(15, t.result);
|
|
|
|
|
|
|
|
a = 1.1;
|
|
|
|
t.x = 1;
|
|
|
|
t.test8();
|
|
|
|
assertEquals(4, t.x);
|
|
|
|
assertEquals(3, t.y);
|
|
|
|
assertEquals(5, t.z);
|
|
|
|
|
|
|
|
t.x = 2;
|
|
|
|
t.test9();
|
|
|
|
assertEquals(14, t.x);
|
|
|
|
assertEquals(6, t.y);
|
|
|
|
assertEquals(15, t.z);
|
|
|
|
|
|
|
|
a = "2";
|
|
|
|
t.test11(a);
|
|
|
|
assertEquals(0, t.z);
|
|
|
|
|
|
|
|
a = 4;
|
|
|
|
b = "1";
|
|
|
|
c = 2;
|
|
|
|
t.test10();
|
|
|
|
assertEquals(2, t.z);
|