node-watch
A wrapper and enhancements for fs.watch.
Installation
npm install node-watch
Example
var watch = require('node-watch');
watch('file_or_dir', { recursive: true }, function(evt, name) {
console.log('%s changed.', name);
});
Now it's fast to watch deep directories on macOS and Windows, since the recursive
option is natively supported except on Linux.
watch('/', { recursive: true }, console.log);
Why?
- Some editors will generate temporary files which will cause the callback function to be triggered multiple times.
- The callback function will only be triggered once on watching a single file.
Missing an option to watch a directory recursively.- Recursive watch is not supported on Linux or in older versions of nodejs.
- Keep it simple, stupid.
Options
The usage and options of node-watch
are compatible with fs.watch.
persistent: Boolean
(default true)recursive: Boolean
(default false)encoding: String
(default 'utf8')
Extra options
-
filter: RegExp | Function
Return that matches the filter expression.
watch('./', { filter: /\.json$/ });
watch('./', { filter: f => !/node_modules/.test(f) });
-
delay: Number
(in ms, default 200)
Delay time of the callback function.
watch('./', { delay: 5000 }, console.log);
Events
The events provided by the callback function is either update
or remove
, which is less confusing to fs.watch
's rename
or change
.
watch('./', function(evt, name) {
if (evt == 'update') {
}
if (evt == 'remove') {
}
});
Watcher object
The watch function returns a fs.FSWatcher like object as the same as fs.watch
(>= v0.4.0).
Watcher events
watcher.on('change', function(evt, name) {
// callback
});
watcher.on('error', function(err) {
// handle error
});
watcher.on('ready', function() {
// the watcher is ready to respond to changes
});
Close
// close
watcher.close();
// is closed?
watcher.isClosed()
List of methods
.on
.once
.emit
.close
.listeners
.setMaxListeners
.getMaxListeners
.isClosed
detect if the watcher is closed
Known issues
Windows
- Will output its parent directory when a new file/directory is created in a deep directory.
Windows, node < v4.2.5
- Failed to detect
remove
event - Failed to get deleted filename or directory name
MacOS, node 0.10.x
- Will emit double event if the directory name is of one single character.
Misc
1. Watch multiple files or directories in one place
watch(['file1', 'file2'], console.log);
2. Customize watch command line tool
#!/usr/bin/env node
require('epipebomb')();
var watcher = require('node-watch')(
process.argv[2] || './', { recursive: true }, console.log
);
process.on('SIGINT', watcher.close);
Monitoring chrome from disk:
$ watch / | grep -i chrome
3. Got ENOSPC error?
If you get ENOSPC error, but you actually have free disk space - it means that your OS watcher limit is too low and you probably want to recursively watch a big tree of files.
Follow this description to increase the limit:
https://confluence.jetbrains.com/display/IDEADEV/Inotify+Watches+Limit
Alternatives
Contributors
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!
License
MIT
Copyright (c) 2012-2018 yuanchuan