Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/npm/node-which
Like which(1) unix command. Find the first instance of an executable in the PATH.
https://github.com/npm/node-which
npm-cli
Last synced: 2 days ago
JSON representation
Like which(1) unix command. Find the first instance of an executable in the PATH.
- Host: GitHub
- URL: https://github.com/npm/node-which
- Owner: npm
- License: isc
- Created: 2011-08-07T18:28:30.000Z (over 13 years ago)
- Default Branch: main
- Last Pushed: 2024-10-03T03:17:47.000Z (2 months ago)
- Last Synced: 2024-11-21T18:05:39.309Z (21 days ago)
- Topics: npm-cli
- Language: JavaScript
- Homepage:
- Size: 186 KB
- Stars: 330
- Watchers: 27
- Forks: 48
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-cross-platform-nodejs - which - Cross-platform implementation of Unix's `which`. (Libraries / Environment)
- awesome-nodejs - which - Cross-platform implementation of Unix's `which`. ![](https://img.shields.io/github/stars/npm/node-which.svg?style=social&label=Star) (Repository / Environment)
- awesome - node-which - Like which(1) unix command. Find the first instance of an executable in the PATH. (Utilities / React Components)
- awesome-javascript - which
- awesome-javascript - which
README
# which
Like the unix `which` utility.
Finds the first instance of a specified executable in the PATH
environment variable. Does not cache the results, so `hash -r` is not
needed when the PATH changes.## USAGE
```javascript
const which = require('which')// async usage
// rejects if not found
const resolved = await which('node')// if nothrow option is used, returns null if not found
const resolvedOrNull = await which('node', { nothrow: true })// sync usage
// throws if not found
const resolved = which.sync('node')// if nothrow option is used, returns null if not found
const resolvedOrNull = which.sync('node', { nothrow: true })// Pass options to override the PATH and PATHEXT environment vars.
await which('node', { path: someOtherPath, pathExt: somePathExt })
```## CLI USAGE
Just like the BSD `which(1)` binary but using `node-which`.
```
usage: node-which [-as] program ...
```You can learn more about why the binary is `node-which` and not `which`
[here](https://github.com/npm/node-which/pull/67)## OPTIONS
You may pass an options object as the second argument.
- `path`: Use instead of the `PATH` environment variable.
- `pathExt`: Use instead of the `PATHEXT` environment variable.
- `all`: Return all matches, instead of just the first one. Note that
this means the function returns an array of strings instead of a
single string.