| OLD | NEW |
| 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, 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 part of scanner; | 5 part of scanner; |
| 6 | 6 |
| 7 class ClassElementParser extends PartialParser { | 7 class ClassElementParser extends PartialParser { |
| 8 ClassElementParser(Listener listener) : super(listener); | 8 ClassElementParser(Listener listener, |
| 9 {bool allowAssertMessage: false}) |
| 10 : super(listener, allowAssertMessage: allowAssertMessage); |
| 9 | 11 |
| 10 Token parseClassBody(Token token) => fullParseClassBody(token); | 12 Token parseClassBody(Token token) => fullParseClassBody(token); |
| 11 } | 13 } |
| 12 | 14 |
| 13 class PartialClassElement extends ClassElementX with PartialElement { | 15 class PartialClassElement extends ClassElementX with PartialElement { |
| 14 ClassNode cachedNode; | 16 ClassNode cachedNode; |
| 15 | 17 |
| 16 PartialClassElement(String name, | 18 PartialClassElement(String name, |
| 17 Token beginToken, | 19 Token beginToken, |
| 18 Token endToken, | 20 Token endToken, |
| (...skipping 22 matching lines...) Expand all Loading... |
| 41 assert(invariant(this, cachedNode != null, | 43 assert(invariant(this, cachedNode != null, |
| 42 message: "Node has not been computed for $this.")); | 44 message: "Node has not been computed for $this.")); |
| 43 return cachedNode; | 45 return cachedNode; |
| 44 } | 46 } |
| 45 | 47 |
| 46 ClassNode parseNode(Compiler compiler) { | 48 ClassNode parseNode(Compiler compiler) { |
| 47 if (cachedNode != null) return cachedNode; | 49 if (cachedNode != null) return cachedNode; |
| 48 compiler.withCurrentElement(this, () { | 50 compiler.withCurrentElement(this, () { |
| 49 compiler.parser.measure(() { | 51 compiler.parser.measure(() { |
| 50 MemberListener listener = new MemberListener(compiler, this); | 52 MemberListener listener = new MemberListener(compiler, this); |
| 51 Parser parser = new ClassElementParser(listener); | 53 Parser parser = new ClassElementParser(listener, |
| 54 allowAssertMessage: compiler.allowAssertMessage); |
| 52 try { | 55 try { |
| 53 Token token = parser.parseTopLevelDeclaration(beginToken); | 56 Token token = parser.parseTopLevelDeclaration(beginToken); |
| 54 assert(identical(token, endToken.next)); | 57 assert(identical(token, endToken.next)); |
| 55 cachedNode = listener.popNode(); | 58 cachedNode = listener.popNode(); |
| 56 assert( | 59 assert( |
| 57 invariant( | 60 invariant( |
| 58 beginToken, listener.nodes.isEmpty, | 61 beginToken, listener.nodes.isEmpty, |
| 59 message: "Non-empty listener stack: ${listener.nodes}")); | 62 message: "Non-empty listener stack: ${listener.nodes}")); |
| 60 } on ParserError { | 63 } on ParserError { |
| 61 // TODO(ahe): Often, a ParserError is thrown while parsing the class | 64 // TODO(ahe): Often, a ParserError is thrown while parsing the class |
| (...skipping 173 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 235 | 238 |
| 236 void endMetadata(Token beginToken, Token periodBeforeName, Token endToken) { | 239 void endMetadata(Token beginToken, Token periodBeforeName, Token endToken) { |
| 237 popNode(); // Discard arguments. | 240 popNode(); // Discard arguments. |
| 238 if (periodBeforeName != null) { | 241 if (periodBeforeName != null) { |
| 239 popNode(); // Discard name. | 242 popNode(); // Discard name. |
| 240 } | 243 } |
| 241 popNode(); // Discard node (Send or Identifier). | 244 popNode(); // Discard node (Send or Identifier). |
| 242 pushMetadata(new PartialMetadataAnnotation(beginToken, endToken)); | 245 pushMetadata(new PartialMetadataAnnotation(beginToken, endToken)); |
| 243 } | 246 } |
| 244 } | 247 } |
| OLD | NEW |