English | 简体中文
A smart package manager with a custom loading style, which makes you install dependencies more beautifully :), and can fuzzy match and find deep-level instructions
- Supports dependency installation, uninstallation, execution and packaging of go mod
- Supports Cargo's dependency installation, uninstallation, execution and packaging
- Support npm dependency installation, uninstallation and execution
- Support pnpm dependency installation, uninstallation and execution
- Support yarn dependency installation, uninstallation and execution
- Automatically handle the difference between yarn and pnpm w and W according to the current directory and environment and will repair the monorepo installation
# Export environment variables in your bash or zsh
# Chinese
export PI_Lang=zh
# English
export PI_Lang=en
npm i -g @simon_he/pi
# According to the environment of the current directory to analyze which package manager to use,go、rust、pnpm、yarn、npm
# Install dependencies
pi xxx
# Uninstall dependencies
pui xxx
# Execute command
prun
# Execute scripts in workspace
pfind
# Initialization
pinit
# build - for cargo, go
pbuild
# pci
The current environment is npm | yarn | pnpm, and it supports passing some args --silent
- prun dev The dev command in the current package.json
- prun If no command is specified, provide all scripts command options under the current package
- prun playground, provide all scripts command options under the current package
The current environment is go
- prun message, it will find message.go first, if not found, it will find message/main.go to execute
The current environment is rust
- prun executable cargo run
workspace of pnpm | yarn
- pfind Select the package under the current workspace, and then select the corresponding command
<-- Go -->
## input folder and executor command
prun # default executor main.go
prun table # if table.go exists, executor table.go else executor table/main.go. and table can under any folder. For example, examples/table/main.go will also be found and executed
<-- Go -->
You can configure the loading style in .zshrc, as follows:
export PI_COLOR=red # loadingstyle color
export PI_SPINNER=star # loadingstyle
export PI_DEFAULT=pnpm # If the current project does not set the installed package manager, you can set the default installation here
- 70+ types of styles, from cli-spinners,You can choose to fill in the name in PI_SPINNER.
- Color options: 'black' | 'red' | 'green' | 'yellow' | 'blue' | 'magenta' | 'cyan' | 'white' | 'gray', Fill in PI_COLOR.