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.
		
		
		
		
		
			
		
			
				
					68 lines
				
				1.4 KiB
			
		
		
			
		
	
	
					68 lines
				
				1.4 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								# 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)
							 |