| fswatch(7) | Miscellaneous Information Manual (fswatch file system monitor) | fswatch(7) | 
fswatch — Ask for
    notification when the contents of the specified files or directory
    hierarchies are modified.
This man page is kept for reference but it is not to be considered
    an authoritative or complete source of information. Please, consult the
    official Info documentation shipped with
  fswatch.
| fswatch (option)* path+ | 
The fswatch command receives notifications
    when the contents of the specified files or directories are modified.
    fswatch implements six kind of monitors:
fswatch writes a record for each event it
    receives containing:
fswatch enters an infinite loop and never
    returns. When it receives a SIGABRT, SIGINT or SIGTERM signal,
    fswatch closes the notification streams and exits
    gracefully returning 0 to the calling process.
The following options are available:
-0,
    --print0-1,
    --one-event--batch-marker
    marker--event
    name-e,
    --exclude regexp-E,
    --extended-f,
    --format-time format-h,
    --help-i,
    --include regexp-I,
    --insensitive-l,
    --latency latency-L,
    --follow-links-M,
    --list-monitors-m,
    --monitor name-h option.-n,
    --numeric-o,
    --one-per-batch-r,
    --recursive-t,
    --timestamp-u,
    --utf-time-v,
    --verbose--versionfswatch and exits.-x,
    --event-flags--event-flag-separator
    separatorfswatch acts as a front-end to
    system-specific monitors. Currently, the available monitors are:
Each monitor has its own strengths, weakness and peculiarities.
    Although fswatch strives to provide a uniform
    experience no matter which monitor is used, it is still important for users
    to know which monitor they are using and to be aware of existing bugs,
    limitations, corner cases or pathological behaviour.
The FSEvents monitor, available only on Apple OS
    X, has no known limitations and scales very well with the number of files
    being observed. In fact, I observed no performance degradation when testing
    fswatch observing changes on a filesystem of 500 GB
    over long periods of time. On OS X, this is the default monitor.
The kqueue monitor, available on any *BSD system
    featuring kqueue, requires a file descriptor to be opened for every file
    being watched. As a result, this monitor scales badly with the number of
    files being observed and may begin to misbehave as soon as the
    fswatch process runs out of file descriptors. In
    this case, fswatch dumps one error on standard error
    for every file that cannot be opened. Beware that on some systems the
    maximum number of file descriptors that can be opened by a process is set to
    a very low value (values as low as 256 are not uncommon), even if the
    operating system may allow a much larger value.
If you are running out of file descriptors when using this monitor and you cannot reduce the number of observed items, either:
The inotify monitor, available on Linux since
    kernel 2.6.13, may suffer a queue overflow if events are generated faster
    than they are read from the queue. In any case, the application is
    guaranteed to receive an overflow notification which can be handled to
    gracefully recover. fswatch currently throws an
    exception if a queue overflow occurs. Future versions will handle the
    overflow by emitting proper notifications. However, the odds of observing a
    queue overflow on a default configured mainstream GNU/Linux distribution is
    very low.
The inotify API sends events for the direct child elements of a watched directory and it scales pretty well with the number of watched items. For this reason, depending on the number of files to watch, it may sometimes be preferable to watch a common parent directory and filter received events rather than adding a huge number of file watches.
The poll monitor was added as a fallback mechanisms in the cases where no other monitor could be used, including:
The poll monitor, available on any platform, only relies on
    available CPU and memory to perform its task (besides the
    stat(2) function). The performance of this monitor
    degrades linearly with the number of files being watched. The authors'
    experience indicates that fswatch requires
    approximately 150 MB or RAM memory to observe a hierarchy of 500.000 files
    with a minimum path length of 32 characters. A common bottleneck of the poll
    monitor is disk access, since stat()-ing a great number of files may take a
    huge amount of time. In this case, the latency should be set to a
    sufficiently large value in order to reduce the performance degradation that
    may result from frequent disk access.
fswatch already chooses the
    "best" monitor for your platform if you do not specify any.
    However, a specific monitor may be better suited to specific use cases.
    Please, read the MONITORS section to get
    a description of all the available monitors and their limitations.
Usage recommendations are as follows:
Received events can be filtered by path using regular expressions. Regular expressions can be used to include or exclude matching paths. The user can specify multiple filter expression in any order and the first matching expression wins.
Other options govern how regular expressions are interpreted:
-E is specified.-I is specified.fswatch syntax is the following:
$ fswatch [options] [paths]
  ...fswatch will then output change events to
    standard output. By default, only the affected file name is printed.
    However, many options are available to format the event record,
  including:
The following command listens for changes in the current directory and events are delivered every 5 seconds:
$ fswatch -l 5 .The following command listens for changes in the current user home directory and /var/log:
$ fswatch ~ /var/logVery often you wish to not only receive an event, but react to it.
    The simplest way to do it is piping fswatch output to another process. Since
    in Unix and Unix-like file system file names may potentially contain any
    character but NUL (\0) and the path separator
    (/),
    fswatch has a specific mode of operation when its
    output must be piped to another process. When the
    [-0] option is used, fswatch
    will use the NUL character as record separator, thus
    allowing any other character to appear in a path. This is important because
    many commands and shell builtins (such as
    read)
    split words and lines by default using the characters in
    $IFS,
    which by default contains characters which may be present (although rarely)
    in a file name, resulting in a wrong event path being received and
    processed.
Probably the simplest way to pipe fswatch
    to another program in order to respond to an event is using
    xargs:
$ fswatch -0 [opts] [paths] | xargs
  -0 -n 1 -I {} [command]fswatch.An often requested feature is being able to receive a single event
    "per batch", instead of receiving multiple events. This use case
    is implemented by the [-o,
    --one-per-batch] option which tells
    fswatch to dump a record containing the number of
    received events, without any other detail:
$ fswatch -or
  /path/to/watch110[...]This is useful if, for example, you want to respond to change events in a way which is (or can easily be) path-independent (because you are not receiving any event detail) and you prefer to "bubble" events together to reduce the overhead of the command being executed. A typical case is a directory synchronisation job whenever some files change.
Another requested feature is the possibility of receiving a single
    event and exit. This is most useful when existing scripts processing events
    include the restart logic of fswatch This use case
    is implemented by the [-1,
    --one-event] option:
$ fswatch -1
  /path/to/watch/path/to/watchThe previous major version of fswatch (v.
    0.x) allowed users to run a command whenever a set of changes was detected
    with the following syntax:
$ fswatch path programStarting with fswatch v. 1.x this
    behaviour is no longer supported. The rationale behind this decision
    includes:
To solve the aforementioned issues and keep
    fswatch consistent with common UNIX practices, the
    behaviour has changed and fswatch now prints event
    records to the standard output that users can process further by piping the
    output of fswatch to other programs.
To fully support the old use, the [-o,
    --one-per-batch] option was added in v. 1.3.3. When
    specified, fswatch will only dump 1 event to
    standard output which can be used to trigger another program:
$ fswatch -o path | xargs -n1
  programIn this case, program will receive the number of change events as first argument. If no argument should be passed to program, then the following command could be used:
$ fswatch -o path | xargs -n1 -I{}
  programAlthough we encourage you to embrace the new
    fswatch behaviour and update your scripts, we
    provide a little wrapper called fswatch-run which is
    installed alongside fswatch which lets you use the
    legacy syntax:
$ fswatch-run path [paths]
  programUnder the hood, fswatch-run simply calls fswatch -o piping its output to xargs.
fswatch-run is a symbolic link to a shell-specific wrapper. Currently, ZSH and Bash scripts are provided. If no suitable shells are found in the target system, the fswatch-run symbolic link is not created.
fswatch may exit with one of the following
    exit statuses:
FSW_OK 0FSW_ERR_UNKNOWN_ERROR (1 <<
  0)FSW_ERR_SESSION_UNKNOWN (1 <<
  1)FSW_ERR_MONITOR_ALREADY_EXISTS (1
  << 2)FSW_ERR_MEMORY (1 <<
  3)FSW_ERR_UNKNOWN_MONITOR_TYPE (1
  << 4)FSW_ERR_CALLBACK_NOT_SET (1 <<
  5)FSW_ERR_PATHS_NOT_SET (1 <<
  6)FSW_ERR_UNKNOWN_MONITOR (1 <<
  7)FSW_ERR_MISSING_CONTEXT (1 <<
  8)FSW_ERR_INVALID_PATH (1 <<
  9)FSW_ERR_INVALID_CALLBACK (1 <<
  10)FSW_ERR_INVALID_LATENCY (1 <<
  11)FSW_ERR_INVALID_REGEX (1 <<
  12)FSW_ERR_MONITOR_ALREADY_RUNNING (1
  << 13)FSW_ERR_STALE_MONITOR_THREAD (1
  << 14)FSW_ERR_THREAD_FAULT (1 <<
  15)FSW_ERR_UNSUPPORTED_OPERATION (1
  << 16)FSW_ERR_UNKNOWN_VALUE (1 <<
  17)fswatch exits 0 on success, and >0 if
    an error occurs.
fswatch can be built on any system
    supporting at least one of the available monitors.
See https://github.com/emcrisostomo/fswatch/issues for open issues or to create a new one.
Bugs can also be submitted to enrico.m.crisostomo@gmail.com.
| September 18, 2022 | pc linux-gnu |