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

Side by Side Diff: utils/pub/system_cache.dart

Issue 10938003: Don't extract the name of a package from its description. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Code review changes Created 8 years, 3 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « utils/pub/source.dart ('k') | utils/pub/version_solver.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, 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 #library('system_cache'); 5 #library('system_cache');
6 6
7 #import('io.dart'); 7 #import('io.dart');
8 #import('package.dart'); 8 #import('package.dart');
9 #import('source.dart'); 9 #import('source.dart');
10 #import('source_registry.dart'); 10 #import('source_registry.dart');
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
54 * Loads all of the package ids in the cache and returns them. 54 * Loads all of the package ids in the cache and returns them.
55 */ 55 */
56 Future<List<PackageId>> listAll() { 56 Future<List<PackageId>> listAll() {
57 return listDir(rootDir).chain((paths) { 57 return listDir(rootDir).chain((paths) {
58 final sources = paths.map((path) { 58 final sources = paths.map((path) {
59 final source = sources[basename(path)]; 59 final source = sources[basename(path)];
60 return listDir(path).transform((subpaths) { 60 return listDir(path).transform((subpaths) {
61 // TODO(rnystrom): Once there are cached packages and this path is 61 // TODO(rnystrom): Once there are cached packages and this path is
62 // being used, figure out how version numbers should be acquired. 62 // being used, figure out how version numbers should be acquired.
63 return subpaths.map((subpath) => 63 return subpaths.map((subpath) =>
64 new PackageId(source, Version.none, basename(subpath))); 64 new PackageId(
65 basename(subpath), source, Version.none, basename(subpath)));
65 }); 66 });
66 }); 67 });
67 return Futures.wait(sources).transform(flatten); 68 return Futures.wait(sources).transform(flatten);
68 }); 69 });
69 } 70 }
70 71
71 /** 72 /**
72 * Ensures that the package identified by [id] is installed to the cache, 73 * Ensures that the package identified by [id] is installed to the cache,
73 * loads it, and returns it. 74 * loads it, and returns it.
74 * 75 *
75 * It is an error to try installing a package from a source with `shouldCache 76 * It is an error to try installing a package from a source with `shouldCache
76 * == false` to the system cache. 77 * == false` to the system cache.
77 */ 78 */
78 Future<Package> install(PackageId id) { 79 Future<Package> install(PackageId id) {
79 if (!id.source.shouldCache) { 80 if (!id.source.shouldCache) {
80 throw new IllegalArgumentException("Package $id is not cacheable."); 81 throw new IllegalArgumentException("Package $id is not cacheable.");
81 } 82 }
82 83
83 var pending = _pendingInstalls[id]; 84 var pending = _pendingInstalls[id];
84 if (pending != null) return pending; 85 if (pending != null) return pending;
85 86
86 var future = id.source.installToSystemCache(id); 87 var future = id.source.installToSystemCache(id);
87 always(future, () => _pendingInstalls.remove(id)); 88 always(future, () => _pendingInstalls.remove(id));
88 _pendingInstalls[id] = future; 89 _pendingInstalls[id] = future;
89 return future; 90 return future;
90 } 91 }
91 } 92 }
OLDNEW
« no previous file with comments | « utils/pub/source.dart ('k') | utils/pub/version_solver.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698