Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(365)

Unified Diff: runtime/vm/flow_graph_range_analysis.cc

Issue 539153002: Port and integrate the irregexp engine from V8 (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Port remaining V8 regexp tests and fix exposed bugs. Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: runtime/vm/flow_graph_range_analysis.cc
diff --git a/runtime/vm/flow_graph_range_analysis.cc b/runtime/vm/flow_graph_range_analysis.cc
index e7268595135fc69c0c29f5866b4f533250618c45..b0ec8cf9d888babd58c0a379acd092c40547c41d 100644
--- a/runtime/vm/flow_graph_range_analysis.cc
+++ b/runtime/vm/flow_graph_range_analysis.cc
@@ -1985,6 +1985,22 @@ void LoadIndexedInstr::InferRange(RangeAnalysis* analysis, Range* range) {
}
+void LoadCodeUnitsInstr::InferRange(RangeAnalysis* analysis, Range* range) {
+ ASSERT(class_id() == kOneByteStringCid ||
+ class_id() == kTwoByteStringCid);
+ switch (class_id()) {
+ case kOneByteStringCid:
+ case kTwoByteStringCid:
+ *range = Range(RangeBoundary::FromConstant(0),
+ RangeBoundary::FromConstant(0xFFFFFFFF));
Florian Schneider 2014/10/01 17:04:15 s/0xFFFFFFFF/kMaxUint32/
jgruber1 2014/10/03 18:59:54 Done.
+ break;
+ default:
+ UNREACHABLE();
+ break;
+ }
+}
+
+
void IfThenElseInstr::InferRange(RangeAnalysis* analysis, Range* range) {
const intptr_t min = Utils::Minimum(if_true_, if_false_);
const intptr_t max = Utils::Maximum(if_true_, if_false_);

Powered by Google App Engine
This is Rietveld 408576698