2017-12-15 10:56:14 -08:00
# read-pkg-up [![Build Status](https://travis-ci.org/sindresorhus/read-pkg-up.svg?branch=master)](https://travis-ci.org/sindresorhus/read-pkg-up)
> Read the closest package.json file
## Why
- [Finds the closest package.json ](https://github.com/sindresorhus/find-up )
- [Gracefully handles filesystem issues ](https://github.com/isaacs/node-graceful-fs )
- [Throws more helpful JSON errors ](https://github.com/sindresorhus/parse-json )
- [Normalizes the data ](https://github.com/npm/normalize-package-data#what-normalization-currently-entails )
## Install
```
2021-05-08 05:39:21 -07:00
$ npm install read-pkg-up
2017-12-15 10:56:14 -08:00
```
## Usage
```js
const readPkgUp = require('read-pkg-up');
2021-05-08 05:39:21 -07:00
(async () => {
console.log(await readPkgUp());
2017-12-15 10:56:14 -08:00
/*
{
2021-05-08 05:39:21 -07:00
packageJson: {
2017-12-15 10:56:14 -08:00
name: 'awesome-package',
version: '1.0.0',
2021-05-08 05:39:21 -07:00
…
2017-12-15 10:56:14 -08:00
},
path: '/Users/sindresorhus/dev/awesome-package/package.json'
}
*/
2021-05-08 05:39:21 -07:00
})();
2017-12-15 10:56:14 -08:00
```
## API
2021-05-08 05:39:21 -07:00
### readPkgUp(options?)
2017-12-15 10:56:14 -08:00
2021-05-08 05:39:21 -07:00
Returns a `Promise<object>` or `Promise<undefined>` if no `package.json` was found.
2017-12-15 10:56:14 -08:00
2021-05-08 05:39:21 -07:00
### readPkgUp.sync(options?)
2017-12-15 10:56:14 -08:00
2021-05-08 05:39:21 -07:00
Returns the result object or `undefined` if no `package.json` was found.
2017-12-15 10:56:14 -08:00
#### options
2021-05-08 05:39:21 -07:00
Type: `object`
2017-12-15 10:56:14 -08:00
##### cwd
2021-05-08 05:39:21 -07:00
Type: `string` \
Default: `process.cwd()`
2017-12-15 10:56:14 -08:00
Directory to start looking for a package.json file.
##### normalize
2021-05-08 05:39:21 -07:00
Type: `boolean` \
2017-12-15 10:56:14 -08:00
Default: `true`
[Normalize ](https://github.com/npm/normalize-package-data#what-normalization-currently-entails ) the package data.
2021-05-08 05:39:21 -07:00
## read-pkg-up for enterprise
Available as part of the Tidelift Subscription.
The maintainers of read-pkg-up and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. [Learn more. ](https://tidelift.com/subscription/pkg/npm-read-pkg-up?utm_source=npm-read-pkg-up&utm_medium=referral&utm_campaign=enterprise&utm_term=repo )
2017-12-15 10:56:14 -08:00
## Related
- [read-pkg ](https://github.com/sindresorhus/read-pkg ) - Read a package.json file
- [pkg-up ](https://github.com/sindresorhus/pkg-up ) - Find the closest package.json file
- [find-up ](https://github.com/sindresorhus/find-up ) - Find a file by walking up parent directories
- [pkg-conf ](https://github.com/sindresorhus/pkg-conf ) - Get namespaced config from the closest package.json