OLD | NEW |
| (Empty) |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | |
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. | |
4 | |
5 library watcher; | |
6 | |
7 import 'dart:async'; | |
8 import 'dart:io'; | |
9 | |
10 import 'src/watch_event.dart'; | |
11 import 'src/directory_watcher.dart'; | |
12 import 'src/file_watcher.dart'; | |
13 | |
14 export 'src/watch_event.dart'; | |
15 export 'src/directory_watcher.dart'; | |
16 export 'src/directory_watcher/polling.dart'; | |
17 export 'src/file_watcher.dart'; | |
18 export 'src/file_watcher/polling.dart'; | |
19 | |
20 abstract class Watcher { | |
21 /// The path to the file or directory whose contents are being monitored. | |
22 String get path; | |
23 | |
24 /// The broadcast [Stream] of events that have occurred to the watched file or | |
25 /// files in the watched directory. | |
26 /// | |
27 /// Changes will only be monitored while this stream has subscribers. Any | |
28 /// changes that occur during periods when there are no subscribers will not | |
29 /// be reported the next time a subscriber is added. | |
30 Stream<WatchEvent> get events; | |
31 | |
32 /// Whether the watcher is initialized and watching for changes. | |
33 /// | |
34 /// This is true if and only if [ready] is complete. | |
35 bool get isReady; | |
36 | |
37 /// A [Future] that completes when the watcher is initialized and watching for | |
38 /// changes. | |
39 /// | |
40 /// If the watcher is not currently monitoring the file or directory (because | |
41 /// there are no subscribers to [events]), this returns a future that isn't | |
42 /// complete yet. It will complete when a subscriber starts listening and the | |
43 /// watcher finishes any initialization work it needs to do. | |
44 /// | |
45 /// If the watcher is already monitoring, this returns an already complete | |
46 /// future. | |
47 Future get ready; | |
48 | |
49 /// Creates a new [DirectoryWatcher] or [FileWatcher] monitoring [path], | |
50 /// depending on whether it's a file or directory. | |
51 /// | |
52 /// If a native watcher is available for this platform, this will use it. | |
53 /// Otherwise, it will fall back to a polling watcher. Notably, watching | |
54 /// individual files is not natively supported on Windows, although watching | |
55 /// directories is. | |
56 /// | |
57 /// If [pollingDelay] is passed, it specifies the amount of time the watcher | |
58 /// will pause between successive polls of the contents of [path]. Making this | |
59 /// shorter will give more immediate feedback at the expense of doing more IO | |
60 /// and higher CPU usage. Defaults to one second. Ignored for non-polling | |
61 /// watchers. | |
62 factory Watcher(String path, {Duration pollingDelay}) { | |
63 if (new File(path).existsSync()) { | |
64 return new FileWatcher(path, pollingDelay: pollingDelay); | |
65 } else { | |
66 return new DirectoryWatcher(path, pollingDelay: pollingDelay); | |
67 } | |
68 } | |
69 } | |
OLD | NEW |