Plugin#
afx's goal is to finally support to install packages as command
, plugin
or both. In afx, several pacakge types (e.g. github
) are supported but you can specify command
and plugin
field in all of sources.
Parameters#
sources#
Type | Default |
---|---|
list | (required) |
sources
allows you to select what to load files when starting shell.
github:
- name: babarot/enhancd
description: A next-generation cd command with your interactive filter
owner: babarot
repo: enhancd
plugin:
env:
ENHANCD_FILTER: fzf --height 25% --reverse --ansi:fzy
sources:
- init.sh
github:
- name: babarot/zsh-prompt-minimal
description: Super super super minimal prompt for zsh
owner: babarot
repo: zsh-prompt-minimal
plugin:
env:
PROMPT_PATH_STYLE: minimal
PROMPT_USE_VIM_MODE: true
sources:
- '*.zsh-theme'
local:
- name: zsh
directory: ~/.zsh
plugin:
sources:
- '[0-9]*.zsh'
env#
Type | Default |
---|---|
map | {} |
env
allows you to set environment variables. By having this section in same YAML file of package declaration, you can manage it with same file. When we don't have afx, we should have environment variables in shell config (e.g. zshrc) even if not installed it yet or failed to install it. But thanks to afx, afx users can keep it with same files and enable it only while a package is installed.
Needs to login new shell
To enable environment variables to your shell, you need to run this command or start new shell after adding this command to your shel config (e.g. .zshrc):
source <(afx init)
github:
- name: babarot/zsh-prompt-minimal
description: Super super super minimal prompt for zsh
owner: babarot
repo: zsh-prompt-minimal
plugin:
env:
PROMPT_PATH_STYLE: minimal
PROMPT_USE_VIM_MODE: true
sources:
- '*.zsh-theme'
snippet#
Type | Default |
---|---|
string | "" |
snippet
allows you to specify the command which are runned when starting new shell.
github:
- name: babarot/enhancd
description: A next-generation cd command with your interactive filter
owner: babarot
repo: enhancd
plugin:
env:
ENHANCD_FILTER: fzf --height 25% --reverse --ansi:fzy
sources:
- init.sh
snippet: |
echo "enhancd is enabled, cd command is overrided by enhancd"
echo "see github.com/babarot/enhancd"
snippet-prepare (beta)#
Type | Default |
---|---|
string | "" |
snippet-prepare
allows you to specify the command which are runned when starting new shell. Unlike snippet
, this snippet-prepare
is run before source
command.
- Run
snippet-prepare
- Load
sources
- Run
snippet
This option comes from #6.
github:
- name: sindresorhus/pure
description: Pretty, minimal and fast ZSH prompt
owner: sindresorhus
repo: pure
plugin:
snippet-prepare: |
zstyle :prompt:pure:git:branch color magenta
zstyle :prompt:pure:git:branch:cached color yellow
zstyle :prompt:pure:git:dirty color 091
zstyle :prompt:pure:user color blue
zstyle :prompt:pure:host color blue
sources:
- pure.zsh
if#
Type | Default |
---|---|
string | "" |
if
allows you to specify the condition to load packages. If it returns true, then the plugin will be loaded. But if it returns false, the plugin will not be loaded.
In if
field, you can write shell scripts1. The exit code finally returned from that shell script is used to determine whether it loads plugin or not.
local:
- name: zsh
directory: ~/.zsh
plugin:
if: |
[[ $SHELL == *zsh* ]]
sources:
- '[0-9]*.zsh'
-
You can configure your favorite shell to evaluate
if
field by settingAFX_SHELL
. ↩