Chromium Code Reviews

Unified Diff: src/ia32/codegen-ia32.cc

Issue 982009: Fix type propagation rules for count operation.... (Closed) Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/
Patch Set: Fixed lint Created 10 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
« no previous file with comments | « no previous file | src/rewriter.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/ia32/codegen-ia32.cc
===================================================================
--- src/ia32/codegen-ia32.cc (revision 4169)
+++ src/ia32/codegen-ia32.cc (working copy)
@@ -6867,7 +6867,12 @@
old_value = allocator_->Allocate();
ASSERT(old_value.is_valid());
__ mov(old_value.reg(), new_value.reg());
+
+ // The old value that is return for postfix operations has the
+ // same type as the input value we got from the frame.
+ old_value.set_number_info(new_value.number_info());
}
+
// Ensure the new value is writable.
frame_->Spill(new_value.reg());
@@ -6931,6 +6936,8 @@
}
deferred->BindExit();
+ // The result of ++ or -- is always a number.
+ new_value.set_number_info(NumberInfo::Number());
// Postfix: store the old value in the allocated slot under the
// reference.
« no previous file with comments | « no previous file | src/rewriter.cc » ('j') | no next file with comments »

Powered by Google App Engine