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 part of dart_backend; | 5 part of dart_backend; |
6 | 6 |
7 // TODO(ahe): This class is simply wrong. This backend should use | 7 // TODO(ahe): This class is simply wrong. This backend should use |
8 // elements when it can, not AST nodes. Perhaps a [Map<Element, | 8 // elements when it can, not AST nodes. Perhaps a [Map<Element, |
9 // TreeElements>] is what is needed. | 9 // TreeElements>] is what is needed. |
10 class ElementAst { | 10 class ElementAst { |
(...skipping 338 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
349 for (Element member in classMembers[classElement]) { | 349 for (Element member in classMembers[classElement]) { |
350 if (member.isConstructor()) continue NextClassElement; | 350 if (member.isConstructor()) continue NextClassElement; |
351 } | 351 } |
352 if (classElement.constructors.isEmpty) continue NextClassElement; | 352 if (classElement.constructors.isEmpty) continue NextClassElement; |
353 | 353 |
354 // TODO(antonm): check with AAR team if there is better approach. | 354 // TODO(antonm): check with AAR team if there is better approach. |
355 // As an idea: provide template as a Dart code---class C { C.name(); }--- | 355 // As an idea: provide template as a Dart code---class C { C.name(); }--- |
356 // and then overwrite necessary parts. | 356 // and then overwrite necessary parts. |
357 var classNode = classElement.parseNode(compiler); | 357 var classNode = classElement.parseNode(compiler); |
358 SynthesizedConstructorElementX constructor = | 358 SynthesizedConstructorElementX constructor = |
359 new SynthesizedConstructorElementX(classElement); | 359 new SynthesizedConstructorElementX( |
| 360 classElement.name, null, classElement); |
360 constructor.type = new FunctionType( | 361 constructor.type = new FunctionType( |
361 constructor, | 362 constructor, |
362 compiler.types.voidType, | 363 compiler.types.voidType, |
363 const Link<DartType>(), | 364 const Link<DartType>(), |
364 const Link<DartType>(), | 365 const Link<DartType>(), |
365 const Link<SourceString>(), | 366 const Link<SourceString>(), |
366 const Link<DartType>() | 367 const Link<DartType>() |
367 ); | 368 ); |
368 constructor.cachedNode = new FunctionExpression( | 369 constructor.cachedNode = new FunctionExpression( |
369 new Send(classNode.name, synthesizedIdentifier), | 370 new Send(classNode.name, synthesizedIdentifier), |
(...skipping 175 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
545 } | 546 } |
546 | 547 |
547 compareElements(e0, e1) { | 548 compareElements(e0, e1) { |
548 int result = compareBy((e) => e.getLibrary().canonicalUri.toString())(e0, e1); | 549 int result = compareBy((e) => e.getLibrary().canonicalUri.toString())(e0, e1); |
549 if (result != 0) return result; | 550 if (result != 0) return result; |
550 return compareBy((e) => e.position().charOffset)(e0, e1); | 551 return compareBy((e) => e.position().charOffset)(e0, e1); |
551 } | 552 } |
552 | 553 |
553 List<Element> sortElements(Iterable<Element> elements) => | 554 List<Element> sortElements(Iterable<Element> elements) => |
554 sorted(elements, compareElements); | 555 sorted(elements, compareElements); |
OLD | NEW |