mirror of
https://github.com/denoland/deno.git
synced 2024-12-21 23:04:45 -05:00
fix: support "other" event type in FSWatcher (#12836)
This commit adds support for "other" events in `FSWatcher`. Flags on events are now exposed via the `flag` property on `FsEvent`.
This commit is contained in:
parent
2eae1ae665
commit
ae34f8fa10
2 changed files with 23 additions and 5 deletions
16
cli/dts/lib.deno.ns.d.ts
vendored
16
cli/dts/lib.deno.ns.d.ts
vendored
|
@ -2007,9 +2007,23 @@ declare namespace Deno {
|
|||
*/
|
||||
export function resources(): ResourceMap;
|
||||
|
||||
/**
|
||||
* Additional information for FsEvent objects with the "other" kind.
|
||||
*
|
||||
* - "rescan": rescan notices indicate either a lapse in the events or a
|
||||
* change in the filesystem such that events received so far can no longer
|
||||
* be relied on to represent the state of the filesystem now. An
|
||||
* application that simply reacts to file changes may not care about this.
|
||||
* An application that keeps an in-memory representation of the filesystem
|
||||
* will need to care, and will need to refresh that representation directly
|
||||
* from the filesystem.
|
||||
*/
|
||||
export type FsEventFlag = "rescan";
|
||||
|
||||
export interface FsEvent {
|
||||
kind: "any" | "access" | "create" | "modify" | "remove";
|
||||
kind: "any" | "access" | "create" | "modify" | "remove" | "other";
|
||||
paths: string[];
|
||||
flag?: FsEventFlag;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -65,8 +65,9 @@ impl Resource for FsEventsResource {
|
|||
/// the complexity.
|
||||
#[derive(Serialize, Debug)]
|
||||
struct FsEvent {
|
||||
kind: String,
|
||||
kind: &'static str,
|
||||
paths: Vec<PathBuf>,
|
||||
flag: Option<&'static str>,
|
||||
}
|
||||
|
||||
impl From<NotifyEvent> for FsEvent {
|
||||
|
@ -77,12 +78,15 @@ impl From<NotifyEvent> for FsEvent {
|
|||
EventKind::Create(_) => "create",
|
||||
EventKind::Modify(_) => "modify",
|
||||
EventKind::Remove(_) => "remove",
|
||||
EventKind::Other => todo!(), // What's this for? Leaving it out for now.
|
||||
}
|
||||
.to_string();
|
||||
EventKind::Other => "other",
|
||||
};
|
||||
let flag = e.flag().map(|f| match f {
|
||||
notify::event::Flag::Rescan => "rescan",
|
||||
});
|
||||
FsEvent {
|
||||
kind,
|
||||
paths: e.paths,
|
||||
flag,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue