1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
"use strict";
((window) => {
const core = window.Deno.core;
const { errors } = window.__bootstrap.errors;
const {
ArrayIsArray,
PromiseResolve,
SymbolAsyncIterator,
} = window.__bootstrap.primordials;
class FsWatcher {
#rid = 0;
constructor(paths, options) {
const { recursive } = options;
this.#rid = core.opSync("op_fs_events_open", { recursive, paths });
}
get rid() {
return this.#rid;
}
async next() {
try {
const value = await core.opAsync("op_fs_events_poll", this.rid);
return value
? { value, done: false }
: { value: undefined, done: true };
} catch (error) {
if (error instanceof errors.BadResource) {
return { value: undefined, done: true };
} else if (error instanceof errors.Interrupted) {
return { value: undefined, done: true };
}
throw error;
}
}
// TODO(kt3k): This is deprecated. Will be removed in v2.0.
// See https://github.com/denoland/deno/issues/10577 for details
return(value) {
core.close(this.rid);
return PromiseResolve({ value, done: true });
}
close() {
core.close(this.rid);
}
[SymbolAsyncIterator]() {
return this;
}
}
function watchFs(
paths,
options = { recursive: true },
) {
return new FsWatcher(ArrayIsArray(paths) ? paths : [paths], options);
}
window.__bootstrap.fsEvents = {
watchFs,
};
})(this);
|