UNPKG

16 kBJavaScriptView Raw
1"use strict";
2var seq = require("./task.sequence");
3var task_runner_1 = require("./task.runner");
4var Rx = require("rx");
5var reporter_resolve_1 = require("./reporter.resolve");
6var command_watch_1 = require("./command.watch");
7var immutable_1 = require("immutable");
8var debug = require("debug")("cb:watch.runner");
9/**
10 * Create a stream that is the combination of all watchers
11 */
12function createObservablesForWatchers(watchers, trigger) {
13 /**
14 * Wrap every chokidar watcher in an observable
15 * @type {Rx.Observable<WatchEvent>[]}
16 */
17 var watchersAsObservables = watchers.map(function (watcher) {
18 return createObservableForWatcher(watcher, trigger);
19 });
20 var blockable$ = new Rx.BehaviorSubject([]);
21 /**
22 * Now map file-change events to task running
23 */
24 return (_a = Rx.Observable).merge.apply(_a, watchersAsObservables)
25 .map(function (watchEvent) {
26 var watcher = watchers.filter(function (x) { return x.watcherUID === watchEvent.watcherUID; })[0];
27 return { watchEvent: watchEvent, watcher: watcher };
28 })
29 .filter(function (x) {
30 if (x.watcher.options.block) {
31 var blocked = !~blockable$.getValue().indexOf(x.watchEvent.watcherUID);
32 debug("BLOCKED - " + x.watchEvent.watcherUID + " " + x.watchEvent.path + " " + x.watchEvent.event);
33 return blocked;
34 }
35 return true;
36 })
37 .do(function (x) {
38 if (x.watcher.options.block) {
39 blockable$.onNext(blockable$.getValue().concat(x.watchEvent.watcherUID));
40 }
41 })
42 .timestamp(trigger.config.scheduler)
43 .flatMap(function (incoming, i) {
44 return runTasks(incoming, i);
45 });
46 function runTasks(incoming, i) {
47 /**
48 * @type {WatchEvent}
49 */
50 var _a = incoming.value, watchEvent = _a.watchEvent, watcher = _a.watcher;
51 return Rx.Observable.create(function (obs) {
52 /**
53 * Report start of task run
54 */
55 trigger.reporter({
56 type: reporter_resolve_1.ReportTypes.WatcherTriggeredTasks,
57 data: {
58 index: i,
59 taskCollection: watcher.tasks
60 }
61 });
62 /**
63 * todo: Is there a way to handle this without subscribing manually?
64 */
65 watcher._runner.series(immutable_1.fromJS({
66 watchEvent: watchEvent,
67 watcher: {
68 patterns: watcher.patterns,
69 tasks: watcher.tasks,
70 options: watcher.options,
71 watcherUID: watcher.watcherUID
72 }
73 }))
74 .do(function (taskReport) { return obs.onNext({
75 type: command_watch_1.WatchCommandEventTypes.WatchTaskReport,
76 data: {
77 taskReport: taskReport,
78 watchEvent: watchEvent,
79 count: i
80 }
81 }); })
82 .toArray()
83 .timestamp(trigger.config.scheduler)
84 .subscribe(function (x) {
85 var reports = x.value;
86 var sequence = seq.decorateSequenceWithReports(watcher._sequence, reports);
87 var errors = reports.filter(function (x) { return x.type === task_runner_1.TaskReportType.error; });
88 obs.onNext({
89 type: command_watch_1.WatchCommandEventTypes.WatchRunnerComplete,
90 data: {
91 sequence: sequence,
92 reports: reports,
93 errors: errors,
94 watchEvent: watchEvent,
95 runtime: x.timestamp - incoming.timestamp
96 }
97 });
98 if (errors.length > 0) {
99 trigger.reporter({
100 type: reporter_resolve_1.ReportTypes.WatcherSummary,
101 data: {
102 sequence: sequence,
103 cli: trigger.cli,
104 title: watcher.tasks.join(", "),
105 config: trigger.config,
106 runtime: x.timestamp - incoming.timestamp,
107 watcher: watcher,
108 watchEvent: watchEvent
109 }
110 });
111 }
112 else {
113 trigger.reporter({
114 type: reporter_resolve_1.ReportTypes.WatcherTriggeredTasksCompleted,
115 data: {
116 index: i,
117 taskCollection: watcher.tasks,
118 time: x.timestamp - incoming.timestamp
119 }
120 });
121 }
122 var withoutThis = blockable$.getValue().filter(function (x) { return x !== watchEvent.watcherUID; });
123 blockable$.onNext(withoutThis);
124 obs.onCompleted();
125 });
126 });
127 }
128 var _a;
129}
130exports.createObservablesForWatchers = createObservablesForWatchers;
131/**
132 * Create a file-system watcher that will emit <WatchEvent>
133 */
134function createObservableForWatcher(watcher, trigger) {
135 var reporter = trigger.reporter;
136 var scheduler = trigger.config.scheduler;
137 /**
138 * First create a stream of file-watcher events for this Watcher
139 */
140 var output$ = trigger.config.fileChangeObserver || getFileChangeStream(watcher, reporter);
141 /**
142 * Specify a mapping from option name -> Rx.Observable operator name
143 */
144 var additionalOperators = [
145 {
146 option: "debounce",
147 fnName: "debounce"
148 },
149 {
150 option: "throttle",
151 fnName: "throttle"
152 },
153 {
154 option: "delay",
155 fnName: "delay"
156 }
157 ];
158 return applyOperators(output$, additionalOperators, watcher.options, scheduler);
159}
160exports.createObservableForWatcher = createObservableForWatcher;
161function getFileChangeStream(watcher, reporter) {
162 /** DEBUG **/
163 debug("[id:" + watcher.watcherUID + "] options: " + JSON.stringify(watcher.options, null, 2));
164 /** DEBUG END **/
165 return Rx.Observable.create(function (observer) {
166 /** DEBUG **/
167 debug("+ [id:" + watcher.watcherUID + "] " + watcher.patterns.length + " patterns (" + watcher.patterns + ")");
168 debug("\u2514\u2500 " + watcher.tasks.length + " tasks (" + watcher.tasks + ")");
169 /** DEBUG END **/
170 var chokidarWatcher = require("chokidar").watch(watcher.patterns, watcher.options)
171 .on("all", function (event, path) {
172 debug("\u2514\u2500 CHOKIDAR EVENT " + event + " - " + path);
173 observer.onNext({
174 event: event,
175 path: path,
176 watcherUID: watcher.watcherUID
177 });
178 });
179 chokidarWatcher.on("ready", function () {
180 /** DEBUG **/
181 debug("\u221A [id:" + watcher.watcherUID + "] watcher ready (" + watcher.patterns + ")");
182 /** DEBUG END **/
183 if (Object.keys(chokidarWatcher.getWatched()).length === 0) {
184 reporter({ type: reporter_resolve_1.ReportTypes.NoFilesMatched, data: { watcher: watcher } });
185 }
186 });
187 return function () {
188 debug("- for " + watcher.patterns);
189 chokidarWatcher.close();
190 };
191 });
192}
193exports.getFileChangeStream = getFileChangeStream;
194/**
195 *
196 */
197function applyOperators(source, items, options, scheduler) {
198 return items.reduce(function (stream$, item) {
199 var value = options[item.option];
200 if (value !== undefined && value > 0) {
201 return stream$[item.fnName].call(stream$, value, scheduler);
202 }
203 return stream$;
204 }, source);
205}
206//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watch.file-watcher.js","sourceRoot":"","sources":["../src/watch.file-watcher.ts"],"names":[],"mappings":"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"}
\No newline at end of file