Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2626)

Unified Diff: sdk/lib/_internal/pub/lib/src/solver/backtracking_solver.dart

Issue 73463003: Support overrides in the version solver. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | sdk/lib/_internal/pub/lib/src/solver/version_solver.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sdk/lib/_internal/pub/lib/src/solver/backtracking_solver.dart
diff --git a/sdk/lib/_internal/pub/lib/src/solver/backtracking_solver.dart b/sdk/lib/_internal/pub/lib/src/solver/backtracking_solver.dart
index 48b84f2104110c32ef01e3439e179f3a1118e317..6a0a53974f117a2e61dd3e31100fc9a426cde6bb 100644
--- a/sdk/lib/_internal/pub/lib/src/solver/backtracking_solver.dart
+++ b/sdk/lib/_internal/pub/lib/src/solver/backtracking_solver.dart
@@ -59,6 +59,13 @@ class BacktrackingSolver {
/// only allow the very latest version for each of these packages.
final _forceLatest = new Set<String>();
+ /// The set of packages whose dependecy is being overridden by the root
+ /// package, keyed by the name of the package.
+ ///
+ /// Any dependency on a package that appears in this map will be overriden
+ /// to use the one here.
+ final _overrides = new Map<String, PackageDep>();
+
/// Every time a package is encountered when traversing the dependency graph,
/// the solver must select a version for it, sometimes when multiple versions
/// are valid. This keeps track of which versions have been selected so far
@@ -83,13 +90,17 @@ class BacktrackingSolver {
var _attemptedSolutions = 1;
BacktrackingSolver(SourceRegistry sources, this.root, this.lockFile,
- List<String> useLatest)
+ Iterable<PackageDep> overrides, List<String> useLatest)
: sources = sources,
cache = new PubspecCache(sources) {
for (var package in useLatest) {
forceLatestVersion(package);
lockFile.packages.remove(package);
}
+
+ for (var override in overrides) {
nweiz 2013/11/15 21:57:16 We should probably detect duplicates in the pubspe
Bob Nystrom 2013/11/16 00:19:10 It's parsed from a map like regular dependencies,
+ _overrides[override.name] = override;
+ }
}
/// Run the solver. Completes with a list of specific package versions if
@@ -381,10 +392,25 @@ class Traverser {
return _solver.cache.getPubspec(id).then((pubspec) {
_validateSdkConstraint(pubspec);
- var deps = pubspec.dependencies.toList();
+ var deps = pubspec.dependencies.toSet();
+
+ if (id.isRoot) {
+ // Include dev dependencies of the root package.
+ deps.addAll(pubspec.devDependencies);
- // Include dev dependencies of the root package.
- if (id.isRoot) deps.addAll(pubspec.devDependencies);
+ // Add all overrides. This ensures a dependency only present as an
+ // override is still included.
+ deps.addAll(_solver._overrides.values);
+ }
+
+ // Replace any overridden dependencies.
+ deps = deps.map((dep) {
+ var override = _solver._overrides[dep.name];
+ if (override != null) return override;
+
+ // Not overridden.
+ return dep;
+ });
// Make sure the package doesn't have any bad dependencies.
for (var dep in deps) {
« no previous file with comments | « no previous file | sdk/lib/_internal/pub/lib/src/solver/version_solver.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698