Index: lib/src/backend/platform_selector/evaluator.dart |
diff --git a/lib/src/backend/platform_selector/evaluator.dart b/lib/src/backend/platform_selector/evaluator.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..d01f0d9c54ba15d9a1eecf4ad8be46fe1187c9c7 |
--- /dev/null |
+++ b/lib/src/backend/platform_selector/evaluator.dart |
@@ -0,0 +1,60 @@ |
+// Copyright (c) 2015, 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. |
+ |
+library unittest.backend.platform_selector.evaluator; |
+ |
+import 'package:source_span/source_span.dart'; |
+ |
+import '../operating_system.dart'; |
+import '../test_platform.dart'; |
+import 'ast.dart'; |
+import 'visitor.dart'; |
+ |
+/// A visitor for evaluating platform selectors against a specific |
+/// [TestPlatform] and [OperatingSystem]. |
+class Evaluator implements Visitor<bool> { |
+ /// The platform to test against. |
+ final TestPlatform _platform; |
+ |
+ /// The operating system to test against. |
+ final OperatingSystem _os; |
+ |
+ Evaluator(this._platform, {OperatingSystem os}) |
+ : _os = os == null ? OperatingSystem.none : os; |
+ |
+ bool visitVariable(VariableNode node) { |
+ if (node.name == _platform.identifier) return true; |
+ if (TestPlatform.all.any((platform) => node.name == platform.identifier)) { |
+ return false; |
+ } |
Bob Nystrom
2015/03/16 16:54:26
Are these false cases needed?
nweiz
2015/03/24 01:03:28
Done.
|
+ |
+ if (node.name == _os.name) return true; |
+ if (OperatingSystem.all.any((os) => node.name == os.name)) { |
+ return false; |
+ } |
+ |
+ switch (node.name) { |
+ case "dart-vm": return _platform.isDartVm; |
+ case "browser": return _platform.isBrowser; |
+ case "dart2js": return _platform.isDart2js; |
+ case "blink": return _platform.isBlink; |
+ case "posix": return _os.isPosix; |
+ default: |
+ throw new SourceSpanFormatException( |
+ 'Undefined variable "${node.name}".', node.span); |
Bob Nystrom
2015/03/16 16:54:26
If you've already done the check for undefined var
nweiz
2015/03/24 01:03:28
Done.
|
+ } |
+ } |
+ |
+ bool visitNot(NotNode node) => !node.child.accept(this); |
+ |
+ bool visitOr(OrNode node) => |
+ node.left.accept(this) || node.right.accept(this); |
+ |
+ bool visitAnd(AndNode node) => |
+ node.left.accept(this) && node.right.accept(this); |
+ |
+ bool visitConditional(ConditionalNode node) => node.condition.accept(this) |
+ ? node.whenTrue.accept(this) |
+ : node.whenFalse.accept(this); |
+} |