You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							126 lines
						
					
					
						
							3.1 KiB
						
					
					
				
			
		
		
	
	
							126 lines
						
					
					
						
							3.1 KiB
						
					
					
				| # make-dir [](https://travis-ci.org/sindresorhus/make-dir) [](https://codecov.io/gh/sindresorhus/make-dir)
 | |
| 
 | |
| > Make a directory and its parents if needed - Think `mkdir -p`
 | |
| 
 | |
| ## Advantages over [`mkdirp`](https://github.com/substack/node-mkdirp)
 | |
| 
 | |
| - Promise API *(Async/await ready!)*
 | |
| - Fixes many `mkdirp` issues: [#96](https://github.com/substack/node-mkdirp/pull/96) [#70](https://github.com/substack/node-mkdirp/issues/70) [#66](https://github.com/substack/node-mkdirp/issues/66)
 | |
| - 100% test coverage
 | |
| - CI-tested on macOS, Linux, and Windows
 | |
| - Actively maintained
 | |
| - Doesn't bundle a CLI
 | |
| - Uses the native `fs.mkdir/mkdirSync` [`recursive` option](https://nodejs.org/dist/latest/docs/api/fs.html#fs_fs_mkdir_path_options_callback) in Node.js >=10.12.0 unless [overridden](#fs)
 | |
| 
 | |
| ## Install
 | |
| 
 | |
| ```
 | |
| $ npm install make-dir
 | |
| ```
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| ```
 | |
| $ pwd
 | |
| /Users/sindresorhus/fun
 | |
| $ tree
 | |
| .
 | |
| ```
 | |
| 
 | |
| ```js
 | |
| const makeDir = require('make-dir');
 | |
| 
 | |
| (async () => {
 | |
| 	const path = await makeDir('unicorn/rainbow/cake');
 | |
| 
 | |
| 	console.log(path);
 | |
| 	//=> '/Users/sindresorhus/fun/unicorn/rainbow/cake'
 | |
| })();
 | |
| ```
 | |
| 
 | |
| ```
 | |
| $ tree
 | |
| .
 | |
| └── unicorn
 | |
|     └── rainbow
 | |
|         └── cake
 | |
| ```
 | |
| 
 | |
| Multiple directories:
 | |
| 
 | |
| ```js
 | |
| const makeDir = require('make-dir');
 | |
| 
 | |
| (async () => {
 | |
| 	const paths = await Promise.all([
 | |
| 		makeDir('unicorn/rainbow'),
 | |
| 		makeDir('foo/bar')
 | |
| 	]);
 | |
| 
 | |
| 	console.log(paths);
 | |
| 	/*
 | |
| 	[
 | |
| 		'/Users/sindresorhus/fun/unicorn/rainbow',
 | |
| 		'/Users/sindresorhus/fun/foo/bar'
 | |
| 	]
 | |
| 	*/
 | |
| })();
 | |
| ```
 | |
| 
 | |
| ## API
 | |
| 
 | |
| ### makeDir(path, options?)
 | |
| 
 | |
| Returns a `Promise` for the path to the created directory.
 | |
| 
 | |
| ### makeDir.sync(path, options?)
 | |
| 
 | |
| Returns the path to the created directory.
 | |
| 
 | |
| #### path
 | |
| 
 | |
| Type: `string`
 | |
| 
 | |
| Directory to create.
 | |
| 
 | |
| #### options
 | |
| 
 | |
| Type: `object`
 | |
| 
 | |
| ##### mode
 | |
| 
 | |
| Type: `integer`\
 | |
| Default: `0o777`
 | |
| 
 | |
| Directory [permissions](https://x-team.com/blog/file-system-permissions-umask-node-js/).
 | |
| 
 | |
| ##### fs
 | |
| 
 | |
| Type: `object`\
 | |
| Default: `require('fs')`
 | |
| 
 | |
| Use a custom `fs` implementation. For example [`graceful-fs`](https://github.com/isaacs/node-graceful-fs).
 | |
| 
 | |
| Using a custom `fs` implementation will block the use of the native `recursive` option if `fs.mkdir` or `fs.mkdirSync` is not the native function.
 | |
| 
 | |
| ## Related
 | |
| 
 | |
| - [make-dir-cli](https://github.com/sindresorhus/make-dir-cli) - CLI for this module
 | |
| - [del](https://github.com/sindresorhus/del) - Delete files and directories
 | |
| - [globby](https://github.com/sindresorhus/globby) - User-friendly glob matching
 | |
| - [cpy](https://github.com/sindresorhus/cpy) - Copy files
 | |
| - [cpy-cli](https://github.com/sindresorhus/cpy-cli) - Copy files on the command-line
 | |
| - [move-file](https://github.com/sindresorhus/move-file) - Move a file
 | |
| 
 | |
| ---
 | |
| 
 | |
| <div align="center">
 | |
| 	<b>
 | |
| 		<a href="https://tidelift.com/subscription/pkg/npm-make-dir?utm_source=npm-make-dir&utm_medium=referral&utm_campaign=readme">Get professional support for this package with a Tidelift subscription</a>
 | |
| 	</b>
 | |
| 	<br>
 | |
| 	<sub>
 | |
| 		Tidelift helps make open source sustainable for maintainers while giving companies<br>assurances about security, maintenance, and licensing for their dependencies.
 | |
| 	</sub>
 | |
| </div>
 |