| // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| import 'package:analyzer/file_system/file_system.dart'; |
| |
| /// Data structure output by PackageMapProvider. This contains both the package |
| /// map and dependency information. |
| class PackageMapInfo { |
| /// The package map itself. This is a map from package name to a list of |
| /// the folders containing source code for the package. |
| /// |
| /// `null` if an error occurred. |
| Map<String, List<Folder>> packageMap; |
| |
| /// Dependency information. This is a set of the paths which were consulted |
| /// in order to generate the package map. If any of these files is |
| /// modified, the package map will need to be regenerated. |
| Set<String> dependencies; |
| |
| PackageMapInfo(this.packageMap, this.dependencies); |
| } |
| |
| /// A PackageMapProvider is an entity capable of determining the mapping from |
| /// package name to source directory for a given folder. |
| abstract class PackageMapProvider { |
| /// Compute a package map for the given folder, if possible. |
| /// |
| /// If a package map can't be computed (e.g. because an error occurred), a |
| /// [PackageMapInfo] will still be returned, but its packageMap will be null. |
| PackageMapInfo computePackageMap(Folder folder); |
| } |