node/deps/npm/node_modules/graceful-fs/README.md

37 lines
1.1 KiB
Markdown
Raw Normal View History

2013-05-15 05:37:59 +08:00
# graceful-fs
2013-05-15 05:37:59 +08:00
graceful-fs functions as a drop-in replacement for the fs module,
making various improvements.
The improvements are meant to normalize behavior across different
platforms and environments, and to make filesystem access more
resilient to errors.
2014-08-01 00:05:30 +08:00
## Improvements over [fs module](http://api.nodejs.org/fs.html)
2013-05-15 05:37:59 +08:00
graceful-fs:
2013-09-08 03:31:04 +08:00
* Queues up `open` and `readdir` calls, and retries them once
something closes if there is an EMFILE error from too many file
descriptors.
2013-05-15 05:37:59 +08:00
* fixes `lchmod` for Node versions prior to 0.6.2.
* implements `fs.lutimes` if possible. Otherwise it becomes a noop.
* ignores `EINVAL` and `EPERM` errors in `chown`, `fchown` or
`lchown` if the user isn't root.
* makes `lchmod` and `lchown` become noops, if not available.
* retries reading a file if `read` results in EAGAIN error.
On Windows, it retries renaming a file for up to one second if `EACCESS`
or `EPERM` error occurs, likely because antivirus software has locked
the directory.
2014-08-01 00:05:30 +08:00
## USAGE
```javascript
// use just like fs
var fs = require('graceful-fs')
// now go and do stuff with it...
fs.readFileSync('some-file-or-whatever')
```