Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pygy/gosub
Run pkg.scripts subtasks in a runner-agnostic way (npm/yarn, whichever launched the main script)
https://github.com/pygy/gosub
npm npm-scripts subtask yarn
Last synced: 3 months ago
JSON representation
Run pkg.scripts subtasks in a runner-agnostic way (npm/yarn, whichever launched the main script)
- Host: GitHub
- URL: https://github.com/pygy/gosub
- Owner: pygy
- License: other
- Created: 2017-11-09T00:19:42.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-12-25T15:11:09.000Z (about 1 year ago)
- Last Synced: 2024-04-27T05:21:24.660Z (9 months ago)
- Topics: npm, npm-scripts, subtask, yarn
- Language: JavaScript
- Homepage:
- Size: 3.91 KB
- Stars: 10
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# gosub
You want to use pkg.scripts subtasks, but you don't want to commit to either `npm run` or `yarn run`? Look no further.
Given the following `package.json`
```JSON
{
"name": "my-package",
"version": "1.0.0",
"license": "MIT",
"scripts": {
"task": "gosub subtask && gosub print done",
"subtask": "echo ====>> unix: $npm_config_user_agent win: %npm_config_user_agent% <<====",
"print":"echo"
},
"devDependencies": {
"gosub": "1.0.0"
}
}
```After running `npm install` or `yarn` you get the following:
```BASH
~/tmp ❯❯❯ yarn run --silent task
$ echo "====>> $npm_config_user_agent <<===="
====>> yarn/1.3.2 npm/? node/v8.9.1 darwin x64 <<====
$ echo done
done
```and
```BASH
~/tmp ❯❯❯ npm run --silent task
====>> npm/5.5.1 node/v8.9.1 darwin x64 <<====
done
```In other words, if the main task is launched with `npm run` the sub tasks will be as well. If you launched it with `yarn run`, so will the subtasks (look between the `===>>` arrows `<<====` ).
This makes your `pkg.scripts` runner agnostic.
## What about other commands beyond `run`?
You can use `gosub --raw action`. So `gosub --raw install` will run `npm install` (re. `bun`, `yarn`, etc...).
## Why not use `$_ run subtask`?
It doesn't work on Windows (although it will save you tens if not hundreds of milliseconds on *nix). If it turns out there's a native, cross-platform method to achieve what `gosub` does please chime in in the issues.
## Caveat
The script works for my own use, but I'm not used to writing command line utilities and may have botched up some details that matter for your use case. For example, this has only been tested on MacOS, althought AFAICT there's nothing OS specific in the script. Feel free to open an issue if you have problems and/or suggestions.
## Is `gosub` a BASIC thing?
\*Waves at all of you who learned to code on 8/16 bits computers\*.
## History
### v2.0.0
- Add a `--raw` option to launch other commands `gosub --raw install` will launch `npm install` (or `bun`, `yarn` depending on what you're using) .
### v1.1.0
- Use `child_process.spawn` instead of `.exec` to prevent the parent from exiting early.
- Have the child inherit the `stdio` streams rather than piping them manually.
- Also pipe `stdin` to the children processes.### v1.0.0
initial release
## License?
Romantic WTF!