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

Side by Side Diff: tests/compiler/dart2js/parser_helper.dart

Issue 1383483006: Extract DiagnosticReporter implementation from Compiler. (Closed) Base URL: https://github.com/dart-lang/sdk.git@master
Patch Set: Created 5 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 library parser_helper; 5 library parser_helper;
6 6
7 import "package:expect/expect.dart"; 7 import "package:expect/expect.dart";
8 8
9 import "package:compiler/src/elements/elements.dart"; 9 import "package:compiler/src/elements/elements.dart";
10 import "package:compiler/src/tree/tree.dart"; 10 import "package:compiler/src/tree/tree.dart";
(...skipping 19 matching lines...) Expand all
30 30
31 export "package:compiler/src/diagnostics/diagnostic_listener.dart"; 31 export "package:compiler/src/diagnostics/diagnostic_listener.dart";
32 export 'package:compiler/src/parser/listener.dart'; 32 export 'package:compiler/src/parser/listener.dart';
33 export 'package:compiler/src/parser/node_listener.dart'; 33 export 'package:compiler/src/parser/node_listener.dart';
34 export 'package:compiler/src/parser/parser.dart'; 34 export 'package:compiler/src/parser/parser.dart';
35 export 'package:compiler/src/parser/partial_parser.dart'; 35 export 'package:compiler/src/parser/partial_parser.dart';
36 export 'package:compiler/src/parser/partial_elements.dart'; 36 export 'package:compiler/src/parser/partial_elements.dart';
37 export "package:compiler/src/tokens/token.dart"; 37 export "package:compiler/src/tokens/token.dart";
38 export "package:compiler/src/tokens/token_constants.dart"; 38 export "package:compiler/src/tokens/token_constants.dart";
39 39
40 class LoggerCanceler extends DiagnosticListener { 40 class LoggerCanceler extends DiagnosticReporter {
41 void log(message) { 41 void log(message) {
42 print(message); 42 print(message);
43 } 43 }
44 44
45 void internalError(node, String message) { 45 void internalError(node, String message) {
46 log(message); 46 log(message);
47 } 47 }
48 48
49 SourceSpan spanFromSpannable(node) { 49 SourceSpan spanFromSpannable(node) {
50 throw 'unsupported operation'; 50 throw 'unsupported operation';
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
86 null, spannable, 86 null, spannable,
87 new Message(MessageTemplate.TEMPLATES[messageKind], arguments, false)); 87 new Message(MessageTemplate.TEMPLATES[messageKind], arguments, false));
88 } 88 }
89 } 89 }
90 90
91 Token scan(String text) => 91 Token scan(String text) =>
92 new StringScanner.fromString(text) 92 new StringScanner.fromString(text)
93 .tokenize(); 93 .tokenize();
94 94
95 Node parseBodyCode(String text, Function parseMethod, 95 Node parseBodyCode(String text, Function parseMethod,
96 {DiagnosticListener diagnosticHandler}) { 96 {DiagnosticReporter reporter}) {
97 Token tokens = scan(text); 97 Token tokens = scan(text);
98 if (diagnosticHandler == null) diagnosticHandler = new LoggerCanceler(); 98 if (reporter == null) reporter = new LoggerCanceler();
99 Uri uri = new Uri(scheme: "source"); 99 Uri uri = new Uri(scheme: "source");
100 Script script = new Script(uri, uri,new MockFile(text)); 100 Script script = new Script(uri, uri,new MockFile(text));
101 LibraryElement library = new LibraryElementX(script); 101 LibraryElement library = new LibraryElementX(script);
102 library.canUseNative = true; 102 library.canUseNative = true;
103 NodeListener listener = 103 NodeListener listener =
104 new NodeListener(diagnosticHandler, library.entryCompilationUnit); 104 new NodeListener(reporter, library.entryCompilationUnit);
105 Parser parser = new Parser(listener); 105 Parser parser = new Parser(listener);
106 Token endToken = parseMethod(parser, tokens); 106 Token endToken = parseMethod(parser, tokens);
107 assert(endToken.kind == EOF_TOKEN); 107 assert(endToken.kind == EOF_TOKEN);
108 Node node = listener.popNode(); 108 Node node = listener.popNode();
109 Expect.isNotNull(node); 109 Expect.isNotNull(node);
110 Expect.isTrue(listener.nodes.isEmpty, 'Not empty: ${listener.nodes}'); 110 Expect.isTrue(listener.nodes.isEmpty, 'Not empty: ${listener.nodes}');
111 return node; 111 return node;
112 } 112 }
113 113
114 Node parseStatement(String text) => 114 Node parseStatement(String text) =>
115 parseBodyCode(text, (parser, tokens) => parser.parseStatement(tokens)); 115 parseBodyCode(text, (parser, tokens) => parser.parseStatement(tokens));
116 116
117 Node parseFunction(String text, Compiler compiler) { 117 Node parseFunction(String text, Compiler compiler) {
118 ElementX element = parseUnit(text, compiler, compiler.mainApp).head; 118 ElementX element = parseUnit(text, compiler, compiler.mainApp).head;
119 Expect.isNotNull(element); 119 Expect.isNotNull(element);
120 Expect.equals(ElementKind.FUNCTION, element.kind); 120 Expect.equals(ElementKind.FUNCTION, element.kind);
121 return element.parseNode(compiler.parsing); 121 return element.parseNode(compiler.parsing);
122 } 122 }
123 123
124 Node parseMember(String text, {DiagnosticListener diagnosticHandler}) { 124 Node parseMember(String text, {DiagnosticReporter reporter}) {
125 return parseBodyCode(text, (parser, tokens) => parser.parseMember(tokens), 125 return parseBodyCode(
126 diagnosticHandler: diagnosticHandler); 126 text,
127 (parser, tokens) => parser.parseMember(tokens),
128 reporter: reporter);
127 } 129 }
128 130
129 class MockFile extends StringSourceFile { 131 class MockFile extends StringSourceFile {
130 MockFile(text) 132 MockFile(text)
131 : super.fromName('<string>', text); 133 : super.fromName('<string>', text);
132 } 134 }
133 135
134 var sourceCounter = 0; 136 var sourceCounter = 0;
135 137
136 Link<Element> parseUnit(String text, Compiler compiler, 138 Link<Element> parseUnit(String text, Compiler compiler,
137 LibraryElement library, 139 LibraryElement library,
138 [void registerSource(Uri uri, String source)]) { 140 [void registerSource(Uri uri, String source)]) {
139 Token tokens = scan(text); 141 Token tokens = scan(text);
140 Uri uri = new Uri(scheme: "source", path: '${++sourceCounter}'); 142 Uri uri = new Uri(scheme: "source", path: '${++sourceCounter}');
141 if (registerSource != null) { 143 if (registerSource != null) {
142 registerSource(uri, text); 144 registerSource(uri, text);
143 } 145 }
144 var script = new Script(uri, uri, new MockFile(text)); 146 var script = new Script(uri, uri, new MockFile(text));
145 var unit = new CompilationUnitElementX(script, library); 147 var unit = new CompilationUnitElementX(script, library);
146 int id = 0; 148 int id = 0;
147 ElementListener listener = new ElementListener(compiler, unit, () => id++); 149 DiagnosticReporter reporter = compiler.reporter;
150 ElementListener listener = new ElementListener(reporter, unit, () => id++);
148 PartialParser parser = new PartialParser(listener); 151 PartialParser parser = new PartialParser(listener);
149 compiler.withCurrentElement(unit, () => parser.parseUnit(tokens)); 152 reporter.withCurrentElement(unit, () => parser.parseUnit(tokens));
150 return unit.localMembers; 153 return unit.localMembers;
151 } 154 }
152 155
153 NodeList fullParseUnit(String source, {DiagnosticListener diagnosticHandler}) { 156 NodeList fullParseUnit(String source, {DiagnosticReporter reporter}) {
154 return parseBodyCode(source, (parser, tokens) => parser.parseUnit(tokens), 157 return parseBodyCode(
155 diagnosticHandler: diagnosticHandler); 158 source,
159 (parser, tokens) => parser.parseUnit(tokens),
160 reporter: reporter);
156 } 161 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698