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

Unified Diff: sdk/lib/_internal/pub_generated/lib/src/barback/pub_package_provider.dart

Issue 597773003: Have barback lazily load assets from static pub packages. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 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 side-by-side diff with in-line comments
Download patch
Index: sdk/lib/_internal/pub_generated/lib/src/barback/pub_package_provider.dart
diff --git a/sdk/lib/_internal/pub_generated/lib/src/barback/pub_package_provider.dart b/sdk/lib/_internal/pub_generated/lib/src/barback/pub_package_provider.dart
index 19f16fb882390946443824018733180ad0761200..cfc70dd265561f7a7a518d525af633308b8abef9 100644
--- a/sdk/lib/_internal/pub_generated/lib/src/barback/pub_package_provider.dart
+++ b/sdk/lib/_internal/pub_generated/lib/src/barback/pub_package_provider.dart
@@ -7,12 +7,16 @@ import '../package_graph.dart';
import '../preprocess.dart';
import '../sdk.dart' as sdk;
import '../utils.dart';
-class PubPackageProvider implements PackageProvider {
+class PubPackageProvider implements StaticPackageProvider {
final PackageGraph _graph;
- final List<String> packages;
+ final List<String> staticPackages;
+ Iterable<String> get packages =>
+ _graph.packages.keys.toSet().difference(staticPackages);
PubPackageProvider(PackageGraph graph)
: _graph = graph,
- packages = [r"$pub", r"$sdk"]..addAll(graph.packages.keys);
+ staticPackages = [
+ r"$pub",
+ r"$sdk"]..addAll(graph.packages.keys.where(graph.isPackageStatic));
Future<Asset> getAsset(AssetId id) {
if (id.package == r'$pub') {
var components = path.url.split(id.path);
@@ -40,4 +44,13 @@ class PubPackageProvider implements PackageProvider {
var file = _graph.packages[id.package].path(nativePath);
return new Future.value(new Asset.fromPath(id, file));
}
+ Stream<AssetId> getAllAssetIds(String packageName) {
+ var package = _graph.packages[packageName];
+ return new Stream.fromIterable(
+ package.listFiles(beneath: 'lib').map((file) {
+ return new AssetId(
+ packageName,
+ path.toUri(package.relative(file)).toString());
+ }));
+ }
}

Powered by Google App Engine
This is Rietveld 408576698