| OLD | NEW |
| 1 // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2016, 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 fasta.named_type_builder; | 5 library fasta.named_type_builder; |
| 6 | 6 |
| 7 import 'builder.dart' | 7 import 'builder.dart' |
| 8 show | 8 show |
| 9 Builder, | 9 Builder, |
| 10 InvalidTypeBuilder, | 10 InvalidTypeBuilder, |
| (...skipping 12 matching lines...) Expand all Loading... |
| 23 NamedTypeBuilder(this.name, this.arguments, int charOffset, Uri fileUri) | 23 NamedTypeBuilder(this.name, this.arguments, int charOffset, Uri fileUri) |
| 24 : super(charOffset, fileUri); | 24 : super(charOffset, fileUri); |
| 25 | 25 |
| 26 InvalidTypeBuilder<T, R> buildInvalidType(String name); | 26 InvalidTypeBuilder<T, R> buildInvalidType(String name); |
| 27 | 27 |
| 28 void bind(TypeDeclarationBuilder builder) { | 28 void bind(TypeDeclarationBuilder builder) { |
| 29 this.builder = builder; | 29 this.builder = builder; |
| 30 } | 30 } |
| 31 | 31 |
| 32 void resolveIn(Scope scope) { | 32 void resolveIn(Scope scope) { |
| 33 if (builder != null) return; |
| 33 Builder member = scope.lookup(name, charOffset, fileUri); | 34 Builder member = scope.lookup(name, charOffset, fileUri); |
| 34 if (member is TypeDeclarationBuilder) { | 35 if (member is TypeDeclarationBuilder) { |
| 35 builder = member; | 36 builder = member; |
| 36 return; | 37 return; |
| 37 } | 38 } |
| 38 if (name.contains(".")) { | 39 if (name.contains(".")) { |
| 39 int index = name.lastIndexOf("."); | 40 int index = name.lastIndexOf("."); |
| 40 String first = name.substring(0, index); | 41 String first = name.substring(0, index); |
| 41 String last = name.substring(name.lastIndexOf(".") + 1); | 42 String last = name.substring(name.lastIndexOf(".") + 1); |
| 42 var prefix = scope.lookup(first, charOffset, fileUri); | 43 var prefix = scope.lookup(first, charOffset, fileUri); |
| 43 if (prefix is PrefixBuilder) { | 44 if (prefix is PrefixBuilder) { |
| 44 member = prefix.lookup(last, charOffset, fileUri); | 45 member = prefix.lookup(last, charOffset, fileUri); |
| 45 } | 46 } |
| 46 if (member is TypeDeclarationBuilder) { | 47 if (member is TypeDeclarationBuilder) { |
| 47 builder = member; | 48 builder = member; |
| 48 return; | 49 return; |
| 49 } | 50 } |
| 50 } | 51 } |
| 51 builder = buildInvalidType(name); | 52 builder = buildInvalidType(name); |
| 52 } | 53 } |
| 53 | 54 |
| 54 String get debugName => "NamedTypeBuilder"; | 55 String get debugName => "NamedTypeBuilder"; |
| 55 | 56 |
| 56 StringBuffer printOn(StringBuffer buffer) { | 57 StringBuffer printOn(StringBuffer buffer) { |
| 57 buffer.write(name); | 58 buffer.write(name); |
| 58 if (arguments == null) return buffer; | 59 if (arguments?.isEmpty ?? true) return buffer; |
| 59 buffer.write("<"); | 60 buffer.write("<"); |
| 60 bool first = true; | 61 bool first = true; |
| 61 for (T t in arguments) { | 62 for (T t in arguments) { |
| 62 if (!first) buffer.write(", "); | 63 if (!first) buffer.write(", "); |
| 63 first = false; | 64 first = false; |
| 64 t.printOn(buffer); | 65 t.printOn(buffer); |
| 65 } | 66 } |
| 66 buffer.write(">"); | 67 buffer.write(">"); |
| 67 return buffer; | 68 return buffer; |
| 68 } | 69 } |
| 69 } | 70 } |
| OLD | NEW |