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

Unified Diff: sdk/lib/_internal/pub/lib/src/barback/sources.dart

Issue 64723005: Use the polling watcher by default in pub tests for now. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: code review 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
Index: sdk/lib/_internal/pub/lib/src/barback/sources.dart
diff --git a/sdk/lib/_internal/pub/lib/src/barback/sources.dart b/sdk/lib/_internal/pub/lib/src/barback/sources.dart
index c85044b75a82e413e6e653e01e327d5d2213ee04..0179591b45bcd48c06e5136c1c3e3985b1e7761e 100644
--- a/sdk/lib/_internal/pub/lib/src/barback/sources.dart
+++ b/sdk/lib/_internal/pub/lib/src/barback/sources.dart
@@ -18,9 +18,12 @@ import '../package_graph.dart';
/// Adds all of the source assets in the provided packages to barback and
/// then watches the public directories for changes.
///
-/// Returns a Future that completes when the sources are loaded and the
-/// watchers are active.
-Future watchSources(PackageGraph graph, Barback barback) {
+/// [watcherFactory] should return a [DirectoryWatcher] watching the given
+/// directory for changes.
+///
+/// Returns a Future that completes when the sources are loaded and the watchers
+/// are active.
+Future watchSources(PackageGraph graph, Barback barback, WatcherType watcher) {
return Future.wait(graph.packages.values.map((package) {
// If this package comes from a cached source, its contents won't change so
// we don't need to monitor it. `packageId` will be null for the application
@@ -39,7 +42,7 @@ Future watchSources(PackageGraph graph, Barback barback) {
if (!dirExists(subdirectory)) return new Future.value();
// TODO(nweiz): close these watchers when [barback] is closed.
- var watcher = new DirectoryWatcher(subdirectory);
+ var watcher = watcher.create(subdirectory);
watcher.events.listen((event) {
// Don't watch files symlinked into these directories.
// TODO(rnystrom): If pub gets rid of symlinks, remove this.
@@ -102,3 +105,47 @@ Iterable<String> _getPublicDirectories(Entrypoint entrypoint, Package package) {
if (package.name == entrypoint.root.name) directories.add("web");
return directories;
}
+
+/// An enum describing different modes of constructing a [DirectoryWatcher].
+abstract class WatcherType {
+ /// A watcher that automatically chooses its type based on the operating
+ /// system.
+ static const AUTO = const _AutoWatcherType();
Bob Nystrom 2013/11/08 19:29:08 I think top-level functions may be usable as const
nweiz 2013/11/08 19:32:10 It feels weird to me to me to have multiple object
+
+ /// A watcher that always polls the filesystem for changes.
+ static const POLLING = const _PollingWatcherType();
+
+ /// No directory watcher at all.
+ static const NONE = const _NoneWatcherType();
+
+ /// Creates a new DirectoryWatcher.
+ DirectoryWatcher create(String directory);
+
+ String toString();
+}
+
+class _AutoWatcherType implements WatcherType {
+ const _AutoWatcherType();
+
+ DirectoryWatcher create(String directory) =>
+ new DirectoryWatcher(directory);
+
+ String toString() => "auto";
+}
+
+class _PollingWatcherType implements WatcherType {
+ const _PollingWatcherType();
+
+ DirectoryWatcher create(String directory) =>
+ new PollingDirectoryWatcher(directory);
+
+ String toString() => "polling";
+}
+
+class _NoneWatcherType implements {
+ const _NoneWatcherType();
+
+ DirectoryWatcher create(String directory) => null;
+
+ String toString() => "none";
+}

Powered by Google App Engine
This is Rietveld 408576698