| OLD | NEW |
| (Empty) |
| 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | |
| 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. | |
| 4 | |
| 5 library source.package_map_provider; | |
| 6 | |
| 7 import 'package:analyzer/file_system/file_system.dart'; | |
| 8 | |
| 9 /** | |
| 10 * Data structure output by PackageMapProvider. This contains both the package | |
| 11 * map and dependency information. | |
| 12 */ | |
| 13 class PackageMapInfo { | |
| 14 /** | |
| 15 * The package map itself. This is a map from package name to a list of | |
| 16 * the folders containing source code for the package. | |
| 17 * | |
| 18 * `null` if an error occurred. | |
| 19 */ | |
| 20 Map<String, List<Folder>> packageMap; | |
| 21 | |
| 22 /** | |
| 23 * Dependency information. This is a set of the paths which were consulted | |
| 24 * in order to generate the package map. If any of these files is | |
| 25 * modified, the package map will need to be regenerated. | |
| 26 */ | |
| 27 Set<String> dependencies; | |
| 28 | |
| 29 PackageMapInfo(this.packageMap, this.dependencies); | |
| 30 } | |
| 31 | |
| 32 /** | |
| 33 * A PackageMapProvider is an entity capable of determining the mapping from | |
| 34 * package name to source directory for a given folder. | |
| 35 */ | |
| 36 abstract class PackageMapProvider { | |
| 37 /** | |
| 38 * Compute a package map for the given folder, if possible. | |
| 39 * | |
| 40 * If a package map can't be computed (e.g. because an error occurred), a | |
| 41 * [PackageMapInfo] will still be returned, but its packageMap will be null. | |
| 42 */ | |
| 43 PackageMapInfo computePackageMap(Folder folder); | |
| 44 } | |
| OLD | NEW |