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

Unified Diff: utils/pub/source.dart

Issue 10803042: Reverting 9767. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 5 months 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 | « utils/pub/repo_source.dart ('k') | utils/pub/version_solver.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: utils/pub/source.dart
diff --git a/utils/pub/source.dart b/utils/pub/source.dart
index 94d00b166f3009eeff9471c97ecf2b15c4c3acdb..acd06f032da8e03b843088dd931a9c62a08f64c4 100644
--- a/utils/pub/source.dart
+++ b/utils/pub/source.dart
@@ -120,8 +120,11 @@ class Source {
Future<Package> installToSystemCache(PackageId id) {
var path = systemCacheDirectory(id);
return exists(path).chain((exists) {
- if (exists) return new Future<bool>.immediate(true);
- return ensureDir(dirname(path)).chain((_) => install(id, path));
+ // TODO(nweiz): better error handling
+ if (exists) throw 'Package $id is already installed.';
+ return ensureDir(dirname(path));
+ }).chain((_) {
+ return install(id, path);
}).chain((found) {
if (!found) throw 'Package $id not found.';
return Package.load(path, systemCache.sources);
@@ -140,17 +143,13 @@ class Source {
join(systemCacheRoot, packageName(id.description));
/**
- * When a [Pubspec] or [LockFile] is parsed, it reads in the description for
- * each dependency. It is up to the dependency's [Source] to determine how
- * that should be interpreted. This will be called during parsing to validate
- * that the given [description] is well-formed according to this source. It
- * should return if the description is valid, or throw a [FormatException] if
- * not.
- *
- * [fromLockFile] is true when the description comes from a [LockFile], to
- * allow the source to use lockfile-specific descriptions via [resolveId].
+ * When a [Pubspec] is parsed, it reads in the description for each
+ * dependency. It is up to the dependency's [Source] to determine how that
+ * should be interpreted. This will be called during parsing to validate that
+ * the given [description] is well-formed according to this source. It should
+ * return if the description is valid, or throw a [FormatException] if not.
*/
- void validateDescription(description, [bool fromLockFile=false]) {}
+ void validateDescription(description) {}
/**
* Returns a human-friendly name for the package described by [description].
@@ -172,27 +171,4 @@ class Source {
*/
bool descriptionsEqual(description1, description2) =>
description1 == description2;
-
- /**
- * For some sources, [PackageId]s can point to different chunks of code at
- * different times. This takes such an [id] and returns a future that
- * completes to a [PackageId] that will uniquely specify a single chunk of
- * code forever.
- *
- * For example, [GitSource] might take an [id] with description
- * `http://github.com/dart-lang/some-lib.git` and return an id with a
- * description that includes the current commit of the Git repository.
- *
- * This will be called after the package identified by [id] is installed, so
- * the source can use the installed package to determine information about the
- * resolved id.
- *
- * The returned [PackageId] may have a description field that's invalid
- * according to [validateDescription], although it must still be serializable
- * to JSON and YAML. It must also be equal to [id] according to
- * [descriptionsEqual].
- *
- * By default, this just returns [id].
- */
- Future<PackageId> resolveId(PackageId id) => new Future.immediate(id);
}
« no previous file with comments | « utils/pub/repo_source.dart ('k') | utils/pub/version_solver.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698