2016-03-18 13:37:29 -05:00
|
|
|
// Copyright (c) 2014-2015 The Notify Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by the MIT license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
// Package notify implements access to filesystem events.
|
|
|
|
//
|
|
|
|
// Notify is a high-level abstraction over filesystem watchers like inotify,
|
|
|
|
// kqueue, FSEvents, FEN or ReadDirectoryChangesW. Watcher implementations are
|
|
|
|
// split into two groups: ones that natively support recursive notifications
|
|
|
|
// (FSEvents and ReadDirectoryChangesW) and ones that do not (inotify, kqueue, FEN).
|
|
|
|
// For more details see watcher and recursiveWatcher interfaces in watcher.go
|
|
|
|
// source file.
|
|
|
|
//
|
|
|
|
// On top of filesystem watchers notify maintains a watchpoint tree, which provides
|
2018-01-02 04:41:47 -06:00
|
|
|
// a strategy for creating and closing filesystem watches and dispatching filesystem
|
2016-03-18 13:37:29 -05:00
|
|
|
// events to user channels.
|
|
|
|
//
|
|
|
|
// An event set is just an event list joint using bitwise OR operator
|
|
|
|
// into a single event value.
|
2018-01-02 04:41:47 -06:00
|
|
|
// Both the platform-independent (see Constants) and specific events can be used.
|
|
|
|
// Refer to the event_*.go source files for information about the available
|
|
|
|
// events.
|
2016-03-18 13:37:29 -05:00
|
|
|
//
|
|
|
|
// A filesystem watch or just a watch is platform-specific entity which represents
|
|
|
|
// a single path registered for notifications for specific event set. Setting a watch
|
|
|
|
// means using platform-specific API calls for creating / initializing said watch.
|
|
|
|
// For each watcher the API call is:
|
|
|
|
//
|
|
|
|
// - FSEvents: FSEventStreamCreate
|
|
|
|
// - inotify: notify_add_watch
|
|
|
|
// - kqueue: kevent
|
|
|
|
// - ReadDirectoryChangesW: CreateFile+ReadDirectoryChangesW
|
|
|
|
// - FEN: port_get
|
|
|
|
//
|
|
|
|
// To rewatch means to either shrink or expand an event set that was previously
|
|
|
|
// registered during watch operation for particular filesystem watch.
|
|
|
|
//
|
|
|
|
// A watchpoint is a list of user channel and event set pairs for particular
|
|
|
|
// path (watchpoint tree's node). A single watchpoint can contain multiple
|
|
|
|
// different user channels registered to listen for one or more events. A single
|
2018-01-02 04:41:47 -06:00
|
|
|
// user channel can be registered in one or more watchpoints, recursive and
|
2016-03-18 13:37:29 -05:00
|
|
|
// non-recursive ones as well.
|
|
|
|
package notify
|