Skip to content

Getting Started#

Install the pre-compiled binary#

You can install the pre-compiled binary (in several different ways), compile from source.

Below you can find the steps for each of them.

bash script#

bash installer has been provided so you can install afx by running this one command at your own risk.

curl -sL https://raw.githubusercontent.com/babarot/afx/HEAD/hack/install | bash
curl -sL https://raw.githubusercontent.com/babarot/afx/HEAD/hack/install | AFX_VERSION=v0.1.24 bash
env description default
AFX_VERSION afx version, available versions are on releases latest
AFX_BIN_DIR Path to install ~/bin

go install#

For Go developers.

go install github.com/babarot/afx@latest

manually#

Download the pre-compiled binaries from the OSS releases page and copy them to the desired location.

Write YAML#

Let's say you want to install jq and enhancd with afx. So please write YAML file like this:

github:
- name: stedolan/jq
  description: Command-line JSON processor
  owner: stedolan
  repo: jq
  release:
    name: jq
    tag: jq-1.6
  command:
    link:
    - from: '*jq*'
      to: jq
- 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

This declaration means afx gets jq v1.6 from GitHub release and install it into PATH as a command.

Okay, then let's save this file in ~/.config/afx/main.yaml.

Install packages#

After preparing YAML files, you become able to run install command:

$ afx install

This command runs install based on what were declared in YAML files.

Initialize packages#

After installed, you need to run this command to enable commands/plugins you installed.

$ source <(afx init)

afx init is just showing what needed to run commands/plugins. As a test, try to run.

$ afx init
source /Users/babarot/.afx/github.com/babarot/enhancd/init.sh
export ENHANCD_FILTER="fzf --height 25% --reverse --ansi:fzy"

As long as you don't run it with source command, it doesn't effect your current shell.

Initialize when starting shell#

Add this command to your shell config (e.g. .zshrc) enable plugins and commands you installed when starting shell.

# enable packages
source <(afx init)

Update packages#

If you want to update package to new version etc, all you have to do is just to modify YAML file and then run afx update:

github:
  - name: stedolan/jq
    description: Command-line JSON processor
    owner: stedolan
    repo: jq
    release:
      name: jq
-     tag: jq-1.5
+     tag: jq-1.6
    command:
      link:
      - from: '*jq*'
        to: jq
$ afx update
✔ stedolan/jq

Configure shell completions#

You can also use shell completion with afx. To enable completion at starting a shell, you need to add below to your each shell "rc" files.

$ source <(afx completion bash)
$ source <(afx completion zsh)
$ afx completion fish | source