Skip to content

How it works#

Where to put YAML#

Example of config directory structure.

In afx, all installation declaration can be kept in YAML files. All configurations should be basically saved in $AFX_CONFIG_PATH. It defaults to ~/.config/afx. You can create YAML files that your package declarations are described and save them in this config directory.

In AFX_CONFIG_PATH, you can keep files with these rules:

  • Naming files as you like is ok
  • Having single file can be ok
  • Deviding into multiple files is also ok
  • Creating sub dir can be also ok

Let's describe each one below.

Single file#

You can create files with any name you like. In above case, declaration of GitHub packages are saved in github.yaml and packages of GitHub Releases are saved in release.yaml. Others (e.g. local etc) are saved in main.yaml.

~/.config/afx
└── afx.yaml

It's ok to keep them in one single file. You can choose which one to suit your style.

Multiple files#

You can divide them into each files to make file name and its contents clear and also put it into one YAML file.

~/.config/afx
├── github.yaml
├── main.yaml
└── release.yaml

Sub directories#

Keeping files in sub directories is also ok. afx tries to walk all directories and find files ending with .yaml or .yml.

~/.config/afx
├── subdir
│  ├── github-1.yaml
│  └── github-2.yaml
├── local.yaml
└── http.yaml

State feature#

afx have a state feature like Terraform. In afx, due to this state feature, what was written in the YAML files means always packages list of what a user desired to install. In short, adding a package declaration to YAML files is to install them to your system and also deleting a package declaration from YAML files is to uninstall from your system.

State in afx

All of package declarations are saved in the state file. Install and uninstall will be run by using the difference between YAML files and records in the state file

  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
+ - name: jhawthorn/fzy
+   description: A better fuzzy finder
+   owner: jhawthorn
+   repo: fzy
+   command:
+     build:
+       steps:
+       - make
+       - sudo make install

After adding package declaration to your YAML, then run this command:

$ afx install
  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
- - name: jhawthorn/fzy
-   description: A better fuzzy finder
-   owner: jhawthorn
-   repo: fzy
-   command:
-     build:
-       steps:
-       - make
-       - sudo make install

After deleting package declaration from your YAML, then run this command:

$ afx uninstall

Localtion of a state file

Location of state file defaults to ~/.afx/state.json. Currently afx does not provide the way to change this path and basically user should not touch this file because it's used internally by afx to keep equivalence between YAML files and its state file. It's likely to be happened unexpected install/uninstall by changing a state file.

Workflow to install packages.

The packages which need to be installed will be calculated from the state file. Then afx installs packages based on the demand of package declarations.

Initialize your commands/plugins#

After installed, basically you need to run afx init command and run source command with the output of that command in order to become able to use commands and plugins you installed.

$ source <(afx init)

This is just an example of afx init. Running source command with this output means these statements are evaluate in current shell. So we can use plugins in current shell and also aliases, variables and so on.

$ afx init
source /Users/babarot/.afx/github.com/babarot/enhancd/init.sh
export ENHANCD_FILTER="fzf --height 25% --reverse --ansi:fzy"
source /Users/babarot/.afx/github.com/zdharma-continuum/history-search-multi-word/history-search-multi-word.plugin.zsh
source /Users/babarot/.afx/github.com/babarot/zsh-vimode-visual/zsh-vimode-visual.zsh
alias diff="colordiff -u"
source /Users/babarot/.afx/github.com/zdharma-continuum/fast-syntax-highlighting/fast-syntax-highlighting.plugin.zsh
source /Users/babarot/.afx/github.com/babarot/zsh-prompt-minimal/minimal.zsh-theme
export PROMPT_PATH_STYLE="minimal"
export PROMPT_USE_VIM_MODE="true"
## package shlide is not installed, so skip to init
source /Users/babarot/.zsh/10_utils.zsh
source /Users/babarot/.zsh/20_keybinds.zsh
source /Users/babarot/.zsh/30_aliases.zsh
source /Users/babarot/.zsh/50_setopt.zsh
source /Users/babarot/.zsh/70_misc.zsh

afx initialize step just only generates these statements based on your YAML files.