Skip to content

crazy-complete/crazy-complete

Repository files navigation

crazy-complete

Every program should have autocompletion in the shell to enhance user experience and productivity. crazy-complete helps solve this task by generating robust and reliable autocompletion scripts.

Key Features:

  • Generates Robust Scripts: Ensures that the autocompletion scripts are reliable and efficient.
  • Multi-Shell Support: Works seamlessly with Bash, Fish, and Zsh, providing flexibility across different environments.
  • Minimal Dependencies: The only external dependency is PyYAML.
  • Configurable and Extendable: The generated autocompletion scripts are highly configurable and can be easily extended to suit your specific needs.
  • Standalone Scripts: The generated scripts are standalone and do not depend on modified environments, unlike some alternatives like argcomplete.
  • Easy to Use: Simple and intuitive to set up, allowing you to quickly add autocompletion functionality to your programs.

With crazy-complete, adding autocompletion to your programs has never been easier. Try it out and see the difference it makes in your command-line applications!

Table of Contents

Benefits of Using crazy-complete

  • Focus on what matters: crazy-complete generates the basic structure of your autocompletion scripts, so you can focus entirely on defining options and their completions instead of dealing with repetitive setup code.

  • Cross-shell consistency: Write your completion logic once and get reliable completions for Bash, Zsh, and Fish, with identical behavior across all shells.

  • Powerful argument completion: crazy-complete provides a rich set of built-in helpers for argument completion and makes it simple to define your own custom argument handlers.

  • Arbitrary levels of subcommands: No matter how deeply nested your CLI structure is, crazy-complete can handle it. You can define completions for commands, subcommands, and even sub-subcommands without extra effort.

  • Full control over options:

    • Repeatable / non-repeatable options: control whether options can be used once or multiple times.
    • Mutually exclusive options: ensure that incompatible options cannot appear together.
    • Conditional options: only suggest options when certain conditions are met.
    • Final options: options that prevent any further options from being completed.
    • Hidden options: completable options that are not shown in the suggestion list.
    • Capturing options: collect options and their values to enable advanced, context-sensitive completions.

Disadvantages of crazy-complete

While crazy-complete offers many advantages, there are some trade-offs to be aware of:

  • Code size and verbosity: Its biggest strength - secure, fully controlled completions - can also be its biggest weakness.
    • For Bash, this means the generated scripts contain a significant amount of boilerplate code for parsing options and positional arguments.
    • For Fish, large command-line definitions (more than 500 options) may result in slower completions, although performance is usually acceptable for most use cases.
    • Mitigation: There are ways to reduce script size and improve performance. See Tips And Tricks for more details.
  • Not as optimized as hand-written scripts: The generated scripts prioritize correctness and reliability over minimal size or maximum performance. Hand-written scripts may be more compact and slightly faster in some cases.

Installation

  • Using Arch Linux:

    Use the *.pkg.tar.zst file that has been released in this repository.

    Or use:

    git clone https://github.com/crazy-complete/crazy-complete
    cd crazy-complete
    makepkg -c && sudo pacman -U python-crazy-complete*.pkg.*
    
  • Using Debian:

    Use the *.deb file that has been released in this repository.

  • Using Fedora / OpenSuse:

    Use the *.rpm file that has been released in this repository.

  • For other Linux distributions:

    git clone https://github.com/crazy-complete/crazy-complete
    cd crazy-complete
    python3 -m pip install .
    

Synopsis

crazy-complete [OPTIONS] {bash,fish,zsh,yaml,json} <DEFINITION_FILE>

See docs/documentation.md#options for a list of options.

Completions for crazy-complete

To install system-wide completion files for crazy-complete, execute the following:

sudo crazy-complete --input-type=python -i bash "$(which crazy-complete)"
sudo crazy-complete --input-type=python -i fish "$(which crazy-complete)"
sudo crazy-complete --input-type=python -i zsh  "$(which crazy-complete)"

If you want to uninstall the completion files, pass -u to crazy-complete:

sudo crazy-complete --input-type=python -u bash "$(which crazy-complete)"
sudo crazy-complete --input-type=python -u fish "$(which crazy-complete)"
sudo crazy-complete --input-type=python -u zsh  "$(which crazy-complete)"

Usage examples

Converting a Python script to YAML:

crazy-complete --input-type=python yaml my_program.py

Generate a YAML file from help text:

grep --help > help_file
crazy-complete --input-type=help yaml help_file
- or -
grep --help | crazy-complete --input-type=help yaml /dev/stdin

Generate shell auto completions for Bash:

crazy-complete --input-type=yaml --include-file my_program.bash bash my_program.yaml

Definition file examples

See examples for examples.

See completions for real world applications of crazy-complete.

You can even have a look at the tests.

Documentation

See docs/documentation.md.

Comparision with other auto-complete generators

See docs/comparision.md for a comparision with other tools.

Questions or problems

Don't hesitate to open an issue on GitHub.