AFX is a package manager for command-line tools and shell plugins. afx can allow us to manage almost all things available on GitHub, Gist and so on. Before, we needed to trawl web pages to download each package one by one. It's very annoying every time we set up new machine and also it's difficult to get how many commands/plugins we installed. So afx's motivation is coming from that and to manage them with YAML files (as a code).
Full document is here: AFX
- Allows to manage various packages types:
- GitHub / GitHub Release / Gist / HTTP (web) / Local
- gh extensions
- Manages as CLI commands, shell plugins or both
- Easy to install/update/uninstall
- Easy to configure with YAML
- Environment variables for each packages
- Aliases for each packges
- Conditional branches
- Build steps
- Run snippet code
- Dependency between packages
- etc...
- Works on bash, zsh and fish
Quick Start plus!
Write YAML file with name as you like in ~/.config/afx/
. Let's say you write this code and then put it into github.yaml
. After than you can install packages with install
command.
+ github:
+ - name: stedolan/jq
+ description: Command-line JSON processor
+ owner: stedolan
+ repo: jq
+ release:
+ name: jq
+ tag: jq-1.5
+ command:
+ link:
+ - from: '*jq*'
+ to: jq
$ afx install
You can enable installed packages to your current shell with this command:
$ source <(afx init)
Take it easy to run afx init
because it just shows what to apply in your shell to Stdout.
If you want to automatically load packages when you start new shell, you need to add above to your shell-rc file.
All you have to do for updating is just to update version part (release.tag) to next version then run update
command.
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
Uninstalling is also almost same as install
. Just to remove unneeded part from YAML file then run uninstall
command.
- 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
$ afx uninstall
For zsh user, you can enable shell completion for afx:
# .zshrc
source <(afx completion zsh)
bash and fish users are also available.
Download the binary from GitHub Release and drop it in your $PATH
.
Or, bash installer has been provided so you can install afx by running this one command at your own risk (detail).
curl -sL https://raw.githubusercontent.com/b4b4r07/afx/HEAD/hack/install | bash
MIT