motion
Version:
motion - moving development forward
109 lines (72 loc) • 4.02 kB
Markdown
# output-file-sync
[](https://www.npmjs.com/package/output-file-sync)
[](https://travis-ci.org/shinnn/output-file-sync)
[](https://ci.appveyor.com/project/ShinnosukeWatanabe/output-file-sync)
[](https://coveralls.io/r/shinnn/output-file-sync)
[](https://david-dm.org/shinnn/output-file-sync)
[](https://david-dm.org/shinnn/output-file-sync#info=devDependencies)
Synchronously write a file and create its ancestor directories if needed
```javascript
const fs = require('fs');
const outputFileSync = require('output-file-sync');
outputFileSync('foo/bar/baz.txt', 'Hi!');
fs.readFileSync('foo/bar/baz.txt').toString(); //=> 'Hi!'
```
## Difference from fs.outputFileSync
This module is very similar to [fs-extra](https://github.com/jprichardson/node-fs-extra)'s [`fs.outputFileSync`](https://github.com/jprichardson/node-fs-extra#outputfilefile-data-callback) but they are different in the following points:
1. *output-file-sync* returns the path of the directory created first. [See the API document for more details.](#outputfilesyncpath-data--options)
2. *output-file-sync* accepts [mkdirp] options.
```javascript
const fs = require('fs');
const outputFileSync = require('output-file-sync');
outputFileSync('foo/bar', 'content', {mode: 33260});
fs.statSync('foo').mode; //=> 33260
```
## Installation
[Use npm.](https://docs.npmjs.com/cli/install)
```
npm install output-file-sync
```
## API
```javascript
const outputFileSync = require('output-file-sync');
```
### outputFileSync(*path*, *data* [, *options*])
*path*: `String`
*data*: `String` or [`Buffer`](https://nodejs.org/api/buffer.html#buffer_class_buffer)
*options*: `Object` or `String` (options for [fs.writeFile] and [mkdirp])
Return: `String` if it creates more than one directories, otherwise `null`
It writes the data to a file synchronously. If ancestor directories of the file don't exist, it creates the directories before writing the file.
```javascript
const fs = require('fs');
const outputFileSync = require('output-file-sync');
// When the directory `foo/bar` exists
outputFileSync('foo/bar/baz/qux.txt', 'Hello', 'utf-8');
fs.statSync('foo/bar/baz').isDirectory(); //=> true
fs.statSync('foo/bar/baz/qux.txt').isFile(); //=> true
```
It returns the directory path just like [mkdirp.sync](https://github.com/substack/node-mkdirp#mkdirpsyncdir-opts):
> Returns the first directory that had to be created, if any.
```javascript
let dir = outputFileSync('foo/bar/baz.txt', 'Hello');
dir; //=> Same value as `path.resolve('foo')`
```
#### options
All options for [fs.writeFile] and [mkdirp] are available.
Additionally, you can use [`fileMode`](#optionsfilemode) option and [`dirMode`](#optionsdirmode) option to set different permission between the file and directories.
##### options.fileMode
Set modes of a file, overriding `mode` option.
##### options.dirMode
Set modes of directories, overriding `mode` option.
```javascript
outputFileSync('dir/file', 'content', {dirMode: '0745', fileMode: '0644'});
fs.statSync('dir').mode.toString(8); //=> '40745'
fs.statSync('dir/file').mode.toString(8); //=> '100644'
```
## Related project
* [output-file](https://github.com/shinnn/output-file) (asynchronous version)
## License
Copyright (c) 2014 - 2015 [Shinnosuke Watanabe](https://github.com/shinnn)
Licensed under [the MIT License](./LICENSE).
[fs.writeFile]: https://nodejs.org/api/fs.html#fs_fs_writefile_filename_data_options_callback
[mkdirp]: https://github.com/substack/node-mkdirp