68 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # 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)
 |