| OLD | NEW |
| 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 Loading... |
| 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 Loading... |
| 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 } |
| OLD | NEW |