Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/egoist/detect-package-manager
Detect which package manager you're using (yarn or pnpm or npm)
https://github.com/egoist/detect-package-manager
npm package-manager pnpm yarn
Last synced: about 2 hours ago
JSON representation
Detect which package manager you're using (yarn or pnpm or npm)
- Host: GitHub
- URL: https://github.com/egoist/detect-package-manager
- Owner: egoist
- License: mit
- Created: 2017-08-11T14:57:30.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2024-08-19T14:02:20.000Z (5 months ago)
- Last Synced: 2025-01-04T06:06:20.550Z (7 days ago)
- Topics: npm, package-manager, pnpm, yarn
- Language: TypeScript
- Homepage:
- Size: 121 KB
- Stars: 76
- Watchers: 4
- Forks: 8
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# detect-package-manager
[![NPM version](https://img.shields.io/npm/v/detect-package-manager.svg?style=flat)](https://npmjs.com/package/detect-package-manager) [![NPM downloads](https://img.shields.io/npm/dm/detect-package-manager.svg?style=flat)](https://npmjs.com/package/detect-package-manager) [![CircleCI](https://circleci.com/gh/egoist/detect-package-manager/tree/master.svg?style=shield)](https://circleci.com/gh/egoist/detect-package-manager/tree/master) [![donate](https://img.shields.io/badge/$-donate-ff69b4.svg?maxAge=2592000&style=flat)](https://github.com/egoist/donate)
## How does this work?
1. When there's `yarn.lock`, `package-lock.json`, `pnpm-lock.yaml`, or `bun.lockb` in current working directory, it will skip other operations and directly resolve `yarn`, `npm`, `pnpm`, or `bun`.
2. When there's no lockfile found, it checks if `yarn`, `pnpm`, or `bun` command exists. If so, it resolves `yarn`, `pnpm`, or `bun` otherwise `npm`.
3. Results are cached.## Install
```bash
yarn add detect-package-manager
```## Usage
```js
const { detect } = require("detect-package-manager");detect().then((pm) => {
console.log(pm);
//=> 'yarn', 'npm', or 'pnpm', 'bun'
});
```## API
### detect([opts])
- Arguments:
- `opts.cwd`: `string` Optional, defaults to `.`, the directory to look up `yarn.lock`, `package-lock.json`, or `pnpm-lock.yaml`.
- `opts.includeGlobalBun`: `boolean` Optional, defaults to `false`, whether to check if `bun` exists in PATH.
- Returns: `Promise`It returns a Promise resolving the name of package manager, could be `npm`, `yarn`, or `pnpm`, `bun`.
### getNpmVersion([pm])
- Arguments:
- `pm`: `string` Optional, defaults to `npm`, could be `npm`, `yarn`, or `pnpm`, `bun`
- Returns: `Promise`It returns a Promise resolving the version of npm or the package manager you specified.
### clearCache()
- Returns: `void`
Clear cache.
## Contributing
1. Fork it!
2. Create your feature branch: `git checkout -b my-new-feature`
3. Commit your changes: `git commit -am 'Add some feature'`
4. Push to the branch: `git push origin my-new-feature`
5. Submit a pull request :D## Author
**detect-package-manager** © [EGOIST](https://github.com/egoist), Released under the [MIT](./LICENSE) License.
Authored and maintained by EGOIST with help from contributors ([list](https://github.com/egoist/detect-package-manager/contributors)).> [github.com/egoist](https://github.com/egoist) · GitHub [@EGOIST](https://github.com/egoist) · Twitter [@\_egoistlily](https://twitter.com/_egoistlily)