1 | ;
|
2 | var seq = require("./task.sequence");
|
3 | var task_runner_1 = require("./task.runner");
|
4 | var Rx = require("rx");
|
5 | var reporter_resolve_1 = require("./reporter.resolve");
|
6 | var command_watch_1 = require("./command.watch");
|
7 | var immutable_1 = require("immutable");
|
8 | var debug = require("debug")("cb:watch.runner");
|
9 | /**
|
10 | * Create a stream that is the combination of all watchers
|
11 | */
|
12 | function 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 | }
|
130 | exports.createObservablesForWatchers = createObservablesForWatchers;
|
131 | /**
|
132 | * Create a file-system watcher that will emit <WatchEvent>
|
133 | */
|
134 | function 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 | }
|
160 | exports.createObservableForWatcher = createObservableForWatcher;
|
161 | function 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 | }
|
193 | exports.getFileChangeStream = getFileChangeStream;
|
194 | /**
|
195 | *
|
196 | */
|
197 | function 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 |