Commit 06a28cbe authored by ager@chromium.org's avatar ager@chromium.org

Fix bug in date code (issue 736) where -0 was not mapped to 0. This caused the

runtime system to throw an exception because it expected smi arguments.


Review URL: http://codereview.chromium.org/2848038

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@5013 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 92f2c471
...@@ -347,9 +347,10 @@ function DateFromTime(t) { ...@@ -347,9 +347,10 @@ function DateFromTime(t) {
function MakeDay(year, month, date) { function MakeDay(year, month, date) {
if (!$isFinite(year) || !$isFinite(month) || !$isFinite(date)) return $NaN; if (!$isFinite(year) || !$isFinite(month) || !$isFinite(date)) return $NaN;
year = TO_INTEGER(year); // Convert to integer and map -0 to 0.
month = TO_INTEGER(month); year = TO_INTEGER_MAP_MINUS_ZERO(year);
date = TO_INTEGER(date); month = TO_INTEGER_MAP_MINUS_ZERO(month);
date = TO_INTEGER_MAP_MINUS_ZERO(date);
if (year < kMinYear || year > kMaxYear || if (year < kMinYear || year > kMaxYear ||
month < kMinMonth || month > kMaxMonth || month < kMinMonth || month > kMaxMonth ||
......
...@@ -120,6 +120,7 @@ macro IS_SPEC_OBJECT_OR_NULL(arg) = (%_IsObject(arg) || %_IsFunction(arg)); ...@@ -120,6 +120,7 @@ macro IS_SPEC_OBJECT_OR_NULL(arg) = (%_IsObject(arg) || %_IsFunction(arg));
# Inline macros. Use %IS_VAR to make sure arg is evaluated only once. # Inline macros. Use %IS_VAR to make sure arg is evaluated only once.
macro NUMBER_IS_NAN(arg) = (!%_IsSmi(%IS_VAR(arg)) && !(arg == arg)); macro NUMBER_IS_NAN(arg) = (!%_IsSmi(%IS_VAR(arg)) && !(arg == arg));
macro TO_INTEGER(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : ToInteger(arg)); macro TO_INTEGER(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : ToInteger(arg));
macro TO_INTEGER_MAP_MINUS_ZERO(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToIntegerMapMinusZero(ToNumber(arg)));
macro TO_INT32(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : (arg >> 0)); macro TO_INT32(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : (arg >> 0));
macro TO_UINT32(arg) = (arg >>> 0); macro TO_UINT32(arg) = (arg >>> 0);
macro TO_STRING_INLINE(arg) = (IS_STRING(%IS_VAR(arg)) ? arg : NonStringToString(arg)); macro TO_STRING_INLINE(arg) = (IS_STRING(%IS_VAR(arg)) ? arg : NonStringToString(arg));
......
...@@ -5368,9 +5368,6 @@ static Object* Runtime_NumberToInteger(Arguments args) { ...@@ -5368,9 +5368,6 @@ static Object* Runtime_NumberToInteger(Arguments args) {
} }
static Object* Runtime_NumberToIntegerMapMinusZero(Arguments args) { static Object* Runtime_NumberToIntegerMapMinusZero(Arguments args) {
NoHandleAllocation ha; NoHandleAllocation ha;
ASSERT(args.length() == 1); ASSERT(args.length() == 1);
......
...@@ -154,6 +154,15 @@ function testToLocaleTimeString() { ...@@ -154,6 +154,15 @@ function testToLocaleTimeString() {
testToLocaleTimeString(); testToLocaleTimeString();
// Test that -0 is treated correctly in MakeDay.
var d = new Date();
assertDoesNotThrow("d.setDate(-0)");
assertDoesNotThrow("new Date(-0, -0, -0, -0, -0, -0. -0)");
assertDoesNotThrow("new Date(0x40000000, 0x40000000, 0x40000000," +
"0x40000000, 0x40000000, 0x40000000, 0x40000000)")
assertDoesNotThrow("new Date(-0x40000001, -0x40000001, -0x40000001," +
"-0x40000001, -0x40000001, -0x40000001, -0x40000001)")
// Modified test from WebKit // Modified test from WebKit
// LayoutTests/fast/js/script-tests/date-utc-timeclip.js: // LayoutTests/fast/js/script-tests/date-utc-timeclip.js:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment