12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- # parent-module [](https://travis-ci.org/sindresorhus/parent-module)
- > Get the path of the parent module
- Node.js exposes `module.parent`, but it only gives you the first cached parent, which is not necessarily the actual parent.
- ## Install
- ```
- $ npm install parent-module
- ```
- ## Usage
- ```js
- // bar.js
- const parentModule = require('parent-module');
- module.exports = () => {
- console.log(parentModule());
- //=> '/Users/sindresorhus/dev/unicorn/foo.js'
- };
- ```
- ```js
- // foo.js
- const bar = require('./bar');
- bar();
- ```
- ## API
- ### parentModule([filepath])
- By default, it will return the path of the immediate parent.
- #### filepath
- Type: `string`<br>
- Default: [`__filename`](https://nodejs.org/api/globals.html#globals_filename)
- Filepath of the module of which to get the parent path.
- Useful if you want it to work [multiple module levels down](https://github.com/sindresorhus/parent-module/tree/master/fixtures/filepath).
- ## Tip
- Combine it with [`read-pkg-up`](https://github.com/sindresorhus/read-pkg-up) to read the package.json of the parent module.
- ```js
- const path = require('path');
- const readPkgUp = require('read-pkg-up');
- const parentModule = require('parent-module');
- console.log(readPkgUp.sync({cwd: path.dirname(parentModule())}).pkg);
- //=> {name: 'chalk', version: '1.0.0', …}
- ```
- ## License
- MIT © [Sindre Sorhus](https://sindresorhus.com)
|