8c04a35c83
There's no point in having %_IsFunction as inline intrinsic, as it is only used in non performance critical code, which is already full of runtime calls anyway, so %IsFunction will do the trick as well. R=yangguo@chromium.org Review URL: https://codereview.chromium.org/1658123002 Cr-Commit-Position: refs/heads/master@{#33660}
40 lines
1023 B
JavaScript
40 lines
1023 B
JavaScript
// Copyright 2014 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 --fold-constants
|
|
|
|
function test() {
|
|
assertEquals("string", typeof "");
|
|
assertEquals("number", typeof 1.1);
|
|
assertEquals("number", typeof 1);
|
|
assertEquals("boolean", typeof true);
|
|
assertEquals("function", typeof function() {});
|
|
assertEquals("object", typeof null);
|
|
assertEquals("object", typeof {});
|
|
assertEquals("object", typeof /regex/);
|
|
|
|
assertTrue(%_IsSmi(1));
|
|
assertFalse(%_IsSmi(1.1));
|
|
assertFalse(%_IsSmi({}));
|
|
|
|
assertTrue(%_IsRegExp(/regexp/));
|
|
assertFalse(%_IsRegExp({}));
|
|
|
|
assertTrue(%_IsArray([1]));
|
|
assertFalse(%_IsArray(function() {}));
|
|
|
|
assertTrue(%_IsJSReceiver(new Date()));
|
|
assertFalse(%_IsJSReceiver(1));
|
|
|
|
assertTrue(%_IsMinusZero(-0.0));
|
|
assertFalse(%_IsMinusZero(1));
|
|
assertFalse(%_IsMinusZero(""));
|
|
}
|
|
|
|
|
|
test();
|
|
test();
|
|
%OptimizeFunctionOnNextCall(test);
|
|
test();
|