Skip to content
/ alf Public

Bash Alias Generator and Manager

License

Notifications You must be signed in to change notification settings

DannyBen/alf

Folders and files

NameName
Last commit message
Last commit date

Latest commit

a4d4caf · Dec 20, 2024
Feb 22, 2024
Jan 14, 2023
Dec 20, 2024
Feb 27, 2024
Mar 8, 2024
Feb 27, 2024
Feb 1, 2020
Mar 23, 2024
Feb 8, 2022
Aug 25, 2023
Mar 23, 2024
Jul 27, 2023
Aug 13, 2020
Feb 27, 2024
Dec 20, 2024
Apr 24, 2019
Feb 29, 2020
Sep 4, 2023
Aug 27, 2023
Dec 20, 2024
Dec 20, 2024
Sep 4, 2023
Sep 4, 2023

Repository files navigation

Alf - Your Little Bash Alias Friend

Version Build Status


Alf enhances your bash alias management. It was developed using the Bashly Command Line Framework.

Features

  • Create aliases by using a config file.
  • Create aliases for sub-commands (for example, g s for git status).
  • Synchronize your aliases across hosts or users by uploading your config file to GitHub.
  • Does not alter anything in your system except for creating the ~/.bash_aliases file, which is normally already sourced by your login process.
  • Works with bash and zsh.

Demo

Demo

Installation

Install the alf executable script:

$ curl -Ls get.dannyb.co/alf/setup | bash

If you prefer to install manually, simply download the alf file, place it somewhere in your path, and make it executable.

Note that alf requires bash 4.0 or higher (brew install bash for mac users).

Using with GitHub-hosted configuration (recommended)

The easiest way to use alf is to create a repository on github, call it alf-conf, and put an alf.conf file in it.

1. Create your own alf-conf repository

2. Connect alf to your repository

$ alf connect <your github user>

3. Save and source your aliases

$ alf save
$ source ~/.bash_aliases  # this normally already exists in your ~/.bashrc

Using without GitHub

If you want to try alf before creating your github repo, use this method to create your bash_aliases file from a local configuration file.

1. Create your alf.conf file

See the sample alf.conf file as a starting point.

2. Save and source your aliases

$ alf save
$ source ~/.bash_aliases

Additional usage patterns

$ alf --help

alf - Your Little Bash Alias Friend

Usage:
  alf [command]
  alf [command] --help | -h
  alf --version | -v

Commands:
  connect    Connect to a remote git repository
  download   Perform git pull on the connected repo
  upload     Perform git commit and push on the connected repo
  generate   Generate aliases to stdout
  save       Generate aliases to ~/.bash_aliases
  edit       Open your alf.conf for editing
  which      Show the alias command
  upgrade    Upgrade alf to the latest version
  info       Show all alf related system facts

Options:
  --help, -h
    Show this help

  --version, -v
    Show version number

Environment Variables:
  ALF_RC_FILE
    Path to alfrc file
    This file holds the path to the alf-conf repository
    Default: ~/.alfrc

File format reference (alf.conf)

Uninstalling

To uninstall alf:

# Run the uninstall script 
$ curl -Ls get.dannyb.co/alf/uninstall | bash

# Optionally, remove .alfrc (exists only if you have performed `alf connect`)
$ rm -f ~/.alfrc

# Optionally, remove .bash_aliases (exists only if you have performed `alf save`)
$ rm -f ~/.bash_aliases

Compatibility

Alf was tested on bash and zsh (and might work with other shells).

In all cases, bash version 4.0 or higher must be installed, since alf uses associative arrays which are not available in older versions.

If your shell does not automatically source ~/.bash_aliases on startup, you should add this line to your startup script:

source ~/.bash_aliases

ZSH Users

Oh-My-Zsh users may skip this step.

If you would like to have autocompletion for alf's sub-aliases and you are using zsh, you should enable completion by adding this to your ~/.zshrc (if is it not already there) before sourcing .bash_aliases:

# Load completion functions
autoload -Uz +X compinit && compinit
autoload -Uz +X bashcompinit && bashcompinit

Related Projects

For a similar project, but for command shortcuts on a per-directory basis, see opcode.

Contributing / Support

If you experience any issue, have a question or a suggestion, or if you wish to contribute, feel free to open an issue.