35 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # fb-watchman
 | |
| 
 | |
| `fb-watchman` is a filesystem watcher that uses the
 | |
| [Watchman](https://facebook.github.io/watchman/) file watching service from
 | |
| Facebook.
 | |
| 
 | |
| Watchman provides file change notification services using very
 | |
| efficient recursive watches and also allows more advanced change matching and
 | |
| filesystem tree querying operations using
 | |
| [a powerful expression syntax](https://facebook.github.io/watchman/docs/file-query.html#expressions).
 | |
| 
 | |
| ## Install
 | |
| 
 | |
| You should [install Watchman](
 | |
| https://facebook.github.io/watchman/docs/install.html) to make the most of this
 | |
| module.
 | |
| 
 | |
| Then simply:
 | |
| 
 | |
| ```
 | |
| $ npm install fb-watchman
 | |
| ```
 | |
| 
 | |
| ## Key Concepts
 | |
| 
 | |
| - Watchman recursively watches directories.
 | |
| - Each watched directory is called a `root`.
 | |
| - You must initiate a `watch` on a `root` using the `watch-project` command prior to subscribing to changes
 | |
| - Rather than separately watching many sibling directories, `watch-project` consolidates and re-uses existing watches relative to a project root (the location of your `.watchmanconfig` or source control repository root)
 | |
| - change notifications are relative to the project root
 | |
| 
 | |
| ## How do I use it?
 | |
| 
 | |
| [Read the NodeJS watchman documentation](https://facebook.github.io/watchman/docs/nodejs.html)
 |