Manage separate shell configurations with ease.
🇸🇪 skal 🇬🇧 shell
npm install --global skal
Run skal
in your terminal to initialize, follow the instructions.
Create and manage profiles under $HOME/.skal/profiles
, use skal
to switch between them.
$ skal --help
Manage separate shell configurations with ease.
Usage
$ skal [<command>]
Commands
new Create a new profile
list List available profiles
which Print path to active profile
edit Edit profile or configuration
Run without arguments for an interactive prompt to switch active profile.
Options
--help Show help
--version Print version
Configure by editing the $HOME/.skal/config.json
file.
Used as a convenience together with the edit
command. Opens configuration or profiles in your editor of choice.
Put the command name you use in your terminal to open your preferred editor.
Example:
{
"editor": "vi"
}
Format:
type Editor = string;
Hooks allows you to optionally run commands in response to switching from/to certain profiles.
Example:
{
"hooks": {
"onSwitchFrom": {
"work": ["cp ~/.npmrcs/default ~/.npmrc"]
},
"onSwitchTo": {
"work": ["cp ~/.npmrcs/work ~/.npmrc"]
}
}
}
Format:
interface Hooks {
onSwitchFrom: HookMap;
onSwitchTo: HookMap;
}
interface HookMap {
[profileName: string]: string[];
}
Keep in mind that hooks are run in a child process.
After running skal
and switching the active profile, the currently active shell needs to be reloaded. The easiest way to do this is to open up a new terminal window or running something equivalent to source "\$HOME/.skal/active"
again.
One way to get around this would be to create a local function re-sourcing after skal
has finished.
# ~/.zshrc
source "$HOME/.skal/active"
function skal() {
command skal "$@"
if (( $# == 0 )) then
source "$HOME/.skal/active"
fi
}
# ~/.config/fish/config.fish
source "$HOME/.skal/active"
function skal
command skal $argv
if test (count $argv) = 0
source "$HOME/.skal/active"
end
end
Node's child_process
module is used to execute hooks. This means that they run in a child process, separate from your currently running shell. Doing something like source "$HOME/.skal/active
inside a hook won't be applied to your terminal shell.