2013-12-12 02:20:26 +08:00
|
|
|
`rm -rf` for node.
|
2011-11-22 01:48:45 +08:00
|
|
|
|
|
|
|
Install with `npm install rimraf`, or just drop rimraf.js somewhere.
|
|
|
|
|
|
|
|
## API
|
|
|
|
|
2012-05-06 13:33:06 +08:00
|
|
|
`rimraf(f, callback)`
|
2011-11-22 01:48:45 +08:00
|
|
|
|
|
|
|
The callback will be called with an error if there is one. Certain
|
|
|
|
errors are handled for you:
|
|
|
|
|
2013-12-12 02:20:26 +08:00
|
|
|
* Windows: `EBUSY` and `ENOTEMPTY` - rimraf will back off a maximum of
|
|
|
|
`opts.maxBusyTries` times before giving up.
|
|
|
|
* `ENOENT` - If the file doesn't exist, rimraf will return
|
|
|
|
successfully, since your desired outcome is already the case.
|
2011-11-22 01:48:45 +08:00
|
|
|
|
|
|
|
## rimraf.sync
|
|
|
|
|
|
|
|
It can remove stuff synchronously, too. But that's not so good. Use
|
|
|
|
the async API. It's better.
|
2013-07-10 04:09:02 +08:00
|
|
|
|
|
|
|
## CLI
|
|
|
|
|
|
|
|
If installed with `npm install rimraf -g` it can be used as a global
|
|
|
|
command `rimraf <path>` which is useful for cross platform support.
|
2013-12-12 02:20:26 +08:00
|
|
|
|
|
|
|
## mkdirp
|
|
|
|
|
|
|
|
If you need to create a directory recursively, check out
|
|
|
|
[mkdirp](https://github.com/substack/node-mkdirp).
|