Go to file
yage 2dcf94199b v1.1.0
=====================================================================

Changed environment dependency checker to be more automatic
2022-07-01 22:17:12 -06:00
docs v1.0.0 2022-07-01 22:16:50 -06:00
py v1.0.0 2022-07-01 22:16:50 -06:00
zsh v1.1.0 2022-07-01 22:17:12 -06:00
zx v1.0.0 2022-07-01 22:16:50 -06:00
.config v1.0.0 2022-07-01 22:16:50 -06:00
.gitattributes v1.1.0 2022-07-01 22:17:12 -06:00
.gitignore v1.0.0 2022-07-01 22:16:50 -06:00
.template.env v1.0.0 2022-07-01 22:16:50 -06:00
LICENSE v1.0.0 2022-07-01 22:16:50 -06:00
README.md v1.0.0 2022-07-01 22:16:50 -06:00
scwrypts v1.1.0 2022-07-01 22:17:12 -06:00
scwrypts.plugin.zsh v1.1.0 2022-07-01 22:17:12 -06:00

Scwrypts (Wryn + Scripts)

Scwrypts is a friendly CLI / API for quickly running sandboxed scripts in the terminal.

In modern developer / dev-ops workflows, scripts require a complex configurations. Without a better solution, the developer is cursed to copy lines-upon-lines of variables into terminals, create random text artifacts, or maybe even commit secure credentials into source. Scwrypts leverages ZSH to give hot-key access to run scripts in such environments.

Dependencies

Due to the wide variety of resources used by scripting libraries, the user is expected to manually resolve dependencies. Dependencies are lazy-loaded, and more information can be found by command error messages or in the appropriate README.

Because Scwrypts relies on Scwrypts (see Meta Scwrypts), zsh must be installed and junegunn/fzf must be available on your PATH.

Usage

Install Scwrypts by cloning this repository and sourcing scwrypts.plugin.zsh in your zshrc. You can now run Scwrypts using the ZLE hotkey bound to SCWRYPTS_SHORTCUT (default CTRL + W).

% cd <path-to-cloned-repo>
% echo "source $(pwd)/scwrypts.plugin.zsh >> $HOME/.zshrc"

Check out Meta Scwrypts to quickly set up environments and adjust configuration.

No Install / API Usage

Alternatively, the scwrypts API can be used directly:

./scwrypts (environment-name) (...script-patterns)

If not already set with $SCWRYPTS_ENV, Scwrypts will try to load $1 as an environment. If no environment with the name $1 is found, $1 is assumed to be a script pattern.

Given one or more script patterns, Scwrypts will filter the commands by pattern conjunction. If only one command is found which matches the pattern(s), it will immediately begin execution. If multiple commands match, the user will be prompted to select from the filtered list. Of course, if no commands match, Scwrypts will exit with an error.

Given no script patterns, Scwrypts becomes an interactive CLI, prompting the user to select a command.

After determining which script to run, if no environment has been specified, Scwrypts prompts the user to choose one.

Contributing

Before contributing an issue, idea, or pull request, check out the super-brief contributing guide