| 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 import 'dart:async'; | 5 import 'dart:async'; |
| 6 | 6 |
| 7 import 'package:analysis_server/src/services/search/search_engine.dart'; | 7 import 'package:analysis_server/src/services/search/search_engine.dart'; |
| 8 import 'package:analyzer/dart/element/element.dart'; | 8 import 'package:analyzer/dart/element/element.dart'; |
| 9 import 'package:analyzer/src/dart/analysis/driver.dart'; | 9 import 'package:analyzer/src/dart/analysis/driver.dart'; |
| 10 import 'package:analyzer/src/dart/analysis/search.dart'; | 10 import 'package:analyzer/src/dart/analysis/search.dart'; |
| 11 import 'package:analyzer/src/generated/source.dart' show Source, SourceRange; | 11 import 'package:analyzer/src/generated/source.dart' show Source, SourceRange; |
| 12 import 'package:meta/meta.dart'; | 12 import 'package:meta/meta.dart'; |
| 13 | 13 |
| 14 /** | 14 /** |
| 15 * A [SearchEngine] implementation. | 15 * A [SearchEngine] implementation. |
| 16 */ | 16 */ |
| 17 class SearchEngineImpl implements SearchEngine { | 17 class SearchEngineImpl implements SearchEngine { |
| 18 final Iterable<AnalysisDriver> _drivers; | 18 final Iterable<AnalysisDriver> _drivers; |
| 19 | 19 |
| 20 SearchEngineImpl(this._drivers); | 20 SearchEngineImpl(this._drivers); |
| 21 | 21 |
| 22 @override | 22 @override |
| 23 Future<Set<String>> membersOfSubtypes(ClassElement type) async { |
| 24 List<AnalysisDriver> drivers = _drivers.toList(); |
| 25 |
| 26 bool hasSubtypes = false; |
| 27 Set<String> visitedIds = new Set<String>(); |
| 28 Set<String> members = new Set<String>(); |
| 29 |
| 30 Future<Null> addMembers(ClassElement type, SubtypeResult subtype) async { |
| 31 if (subtype != null && !visitedIds.add(subtype.id)) { |
| 32 return; |
| 33 } |
| 34 for (AnalysisDriver driver in drivers) { |
| 35 List<SubtypeResult> subtypes = |
| 36 await driver.search.subtypes(type: type, subtype: subtype); |
| 37 for (var subtype in subtypes) { |
| 38 hasSubtypes = true; |
| 39 members.addAll(subtype.members); |
| 40 await addMembers(null, subtype); |
| 41 } |
| 42 } |
| 43 } |
| 44 |
| 45 await addMembers(type, null); |
| 46 |
| 47 if (!hasSubtypes) { |
| 48 return null; |
| 49 } |
| 50 return members; |
| 51 } |
| 52 |
| 53 @override |
| 23 Future<Set<ClassElement>> searchAllSubtypes(ClassElement type) async { | 54 Future<Set<ClassElement>> searchAllSubtypes(ClassElement type) async { |
| 24 Set<ClassElement> allSubtypes = new Set<ClassElement>(); | 55 Set<ClassElement> allSubtypes = new Set<ClassElement>(); |
| 25 | 56 |
| 26 Future<Null> addSubtypes(ClassElement type) async { | 57 Future<Null> addSubtypes(ClassElement type) async { |
| 27 List<SearchResult> directResults = await _searchDirectSubtypes(type); | 58 List<SearchResult> directResults = await _searchDirectSubtypes(type); |
| 28 for (SearchResult directResult in directResults) { | 59 for (SearchResult directResult in directResults) { |
| 29 var directSubtype = directResult.enclosingElement as ClassElement; | 60 var directSubtype = directResult.enclosingElement as ClassElement; |
| 30 if (allSubtypes.add(directSubtype)) { | 61 if (allSubtypes.add(directSubtype)) { |
| 31 await addSubtypes(directSubtype); | 62 await addSubtypes(directSubtype); |
| 32 } | 63 } |
| (...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 195 } | 226 } |
| 196 if (kind == SearchResultKind.WRITE) { | 227 if (kind == SearchResultKind.WRITE) { |
| 197 return MatchKind.WRITE; | 228 return MatchKind.WRITE; |
| 198 } | 229 } |
| 199 if (kind == SearchResultKind.INVOCATION) { | 230 if (kind == SearchResultKind.INVOCATION) { |
| 200 return MatchKind.INVOCATION; | 231 return MatchKind.INVOCATION; |
| 201 } | 232 } |
| 202 return MatchKind.REFERENCE; | 233 return MatchKind.REFERENCE; |
| 203 } | 234 } |
| 204 } | 235 } |
| OLD | NEW |