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

Unified Diff: tests/language/const_nested_test.dart

Issue 11265047: Implement const expressions for local variables (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 8 years, 1 month 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: tests/language/const_nested_test.dart
===================================================================
--- tests/language/const_nested_test.dart (revision 0)
+++ tests/language/const_nested_test.dart (revision 0)
@@ -0,0 +1,35 @@
+// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
+// for details. All rights reserved. Use of this source code is governed by a
+// BSD-style license that can be found in the LICENSE file.
+
+// Test of compile time constant local variables in outer function levels.
+
+const N = 8;
+
+class ConstFoo {
+ final x;
+ const ConstFoo(this.x);
+}
+
+main() {
+ const MIN = 2 - 1;
+ const MAX = N * 2;
+ const MASK = (1 << (MAX - MIN + 1)) - 1;
siva 2012/11/08 20:30:01 const MASK = (1 << (MAX - MIN + 1)) - 1; // 65535
hausner 2012/11/09 00:10:21 Done.
+ void foo() {
+ Expect.equals(1, MIN);
+ Expect.equals(16, MAX);
+ Expect.equals(65535, MASK);
+ // Refer to compile time constant local variables in outer scope.
+ const s = 'MIN = $MIN MAX = $MAX MASK = $MASK';
+ Expect.isTrue(s === 'MIN = $MIN MAX = $MAX MASK = $MASK');
+ Expect.equals("MIN = 1 MAX = 16 MASK = 65535", s);
+ var cf1 = const ConstFoo(MASK);
+ var cf2 = const ConstFoo(s);
+ var cf3 = const ConstFoo('MIN = $MIN MAX = $MAX MASK = $MASK');
+ Expect.isTrue(cf2 === cf3);
siva 2012/11/08 20:30:01 Expect.isFalse(cf2 === cf1);
hausner 2012/11/09 00:10:21 Done.
+ }
+ foo();
siva 2012/11/08 20:30:01 foo() should be returned as a closure and invoked
hausner 2012/11/09 00:10:21 Done.
+}
+
+
+

Powered by Google App Engine
This is Rietveld 408576698