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

Unified Diff: sdk/lib/_internal/compiler/implementation/constant_system_dart.dart

Issue 682243004: Redo "Constant fold charCodeAt via constant system" (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Fix analysis warning Created 6 years, 2 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: sdk/lib/_internal/compiler/implementation/constant_system_dart.dart
diff --git a/sdk/lib/_internal/compiler/implementation/constant_system_dart.dart b/sdk/lib/_internal/compiler/implementation/constant_system_dart.dart
index 624d967e47ee75dd93ba0217fce0ef113471d04a..1cc239d8f52318904d42a4849f3cda03170801c8 100644
--- a/sdk/lib/_internal/compiler/implementation/constant_system_dart.dart
+++ b/sdk/lib/_internal/compiler/implementation/constant_system_dart.dart
@@ -318,6 +318,37 @@ class IdentityOperation implements BinaryOperation {
apply(left, right) => identical(left, right);
}
+abstract class CodeUnitAtOperation implements BinaryOperation {
+ final String name = 'charCodeAt';
+ const CodeUnitAtOperation();
+ apply(left, right) => left.codeUnitAt(right);
+}
+
+class CodeUnitAtConstantOperation extends CodeUnitAtOperation {
+ const CodeUnitAtConstantOperation();
+ ConstantValue fold(ConstantValue left, ConstantValue right) {
+ // 'a'.codeUnitAt(0) is not a constant expression.
+ return null;
+ }
+}
+
+class CodeUnitAtRuntimeOperation extends CodeUnitAtOperation {
+ const CodeUnitAtRuntimeOperation();
+ IntConstantValue fold(ConstantValue left, ConstantValue right) {
+ if (left.isString && right.isInt) {
+ StringConstantValue stringConstant = left;
+ IntConstantValue indexConstant = right;
+ DartString dartString = stringConstant.primitiveValue;
+ int index = indexConstant.primitiveValue;
+ if (index < 0 || index >= dartString.length) return null;
+ String string = dartString.slowToString();
+ int value = string.codeUnitAt(index);
+ return DART_CONSTANT_SYSTEM.createInt(value);
+ }
+ return null;
+ }
+}
+
/**
* A constant system implementing the Dart semantics. This system relies on
* the underlying runtime-system. That is, if dart2js is run in an environment
@@ -347,6 +378,7 @@ class DartConstantSystem extends ConstantSystem {
final shiftRight = const ShiftRightOperation();
final subtract = const SubtractOperation();
final truncatingDivide = const TruncatingDivideOperation();
+ final codeUnitAt = const CodeUnitAtConstantOperation();
const DartConstantSystem();

Powered by Google App Engine
This is Rietveld 408576698