|
|
- /// <reference types="node"/>
- import * as fs from 'fs';
-
- export interface Options {
- /**
- * Directory [permissions](https://x-team.com/blog/file-system-permissions-umask-node-js/).
- *
- * @default 0o777 & (~process.umask())
- */
- readonly mode?: number;
-
- /**
- * 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.
- *
- * @default require('fs')
- */
- readonly fs?: typeof fs;
- }
-
- /**
- * Make a directory and its parents if needed - Think `mkdir -p`.
- *
- * @param path - Directory to create.
- * @returns A `Promise` for the path to the created directory.
- */
- export default function makeDir(
- path: string,
- options?: Options
- ): Promise<string>;
-
- /**
- * Synchronously make a directory and its parents if needed - Think `mkdir -p`.
- *
- * @param path - Directory to create.
- * @returns The path to the created directory.
- */
- export function sync(path: string, options?: Options): string;
|