Skip to main content

Shell Genie is a command-line tool that lets you interact with the terminal in plain English. You ask the genie what you want to do and it will give you the command you need.

Project description

🧞‍♂️ Shell Genie

Your wishes are my commands.

Shell Genie is a command-line tool that lets you interact with the terminal in plain English. You ask the genie what you want to do and it will give you the command you need.

Installation

The recommended way to install Shell Genie is using pipx:

  1. Install Python 3.10 or higher.
  2. Install pipx.
  3. Install Shell Genie: pipx install shell-genie

Alternatively, you can install it using pip:

  1. Install Python 3.10 or higher.
  2. Create a virtual environment in your preferred location: python -m venv .venv
  3. Activate the virtual environment: source .venv/bin/activate
  4. Install Shell Genie: pip install shell-genie

How to use

  1. First, you need to initialize the tool by running the following command:

    shell-genie init
    

    This will prompt you to select a backend (either openai-gpt3 or free-genie) and provide any additional information that is required (e.g. your own OpenAI API key for openai-gpt3).

    The free-genie backend is free to use. I'm hosting it, and as you can imagine I'm not a big corporation with unlimited money, so there's no guarantee that it will be available at all times. My goal is to generate a dataset of commands to fine-tune a model later on (this is mentioned during the initialization process).

  2. Once you have initialized the tool, you can start asking the genie what you want to do. For example, you may ask it to find all the json files in the current directory that are larger than 1MB:

    shell-genie ask "find all json files in the current directory that are larger than 1MB"
    

    You'll see an output similar to this:

    Command: find . -name "*.json" -size +1M
    Do you want to run this command? [y/n]:
    

    If you have questions about how the command works, you can ask the genie to explain it:

    shell-genie ask "find all json files in the current directory that are larger than 1MB" --explain
    

    And you'll see an output similar to this:

    Command: find . -name "*.json" -size +1M
    Description: This command will search the current directory for all... (shortened for brevity)
    Do you want to run the command? [y/n]:
    
  3. Run the command if you want to. If you're using free-genie, and you want to help improve the tool, you can provide feedback after you've run the command.

Examples

Here are two short videos showing how to use the tool:

Limitations

As you can imagine not all the commands provided by the genie work as expected. Use them at your own risk.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

shell_genie-0.2.6.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

shell_genie-0.2.6-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file shell_genie-0.2.6.tar.gz.

File metadata

  • Download URL: shell_genie-0.2.6.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.4 Darwin/22.3.0

File hashes

Hashes for shell_genie-0.2.6.tar.gz
Algorithm Hash digest
SHA256 3204051ec057ae285f58107f733e392137fca091b68127a77f5c3375bac06e3c
MD5 6e10e792836277829a28eb6c241914d6
BLAKE2b-256 132de6ce7ed1592fc00ea486b4709431f5ead1defcb35d165d381a0279a4a0f6

See more details on using hashes here.

File details

Details for the file shell_genie-0.2.6-py3-none-any.whl.

File metadata

  • Download URL: shell_genie-0.2.6-py3-none-any.whl
  • Upload date:
  • Size: 5.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.4 Darwin/22.3.0

File hashes

Hashes for shell_genie-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 4c0349f241794491cc238ec3d6a5343f97bc031030155413ced2f9c66f5e5168
MD5 3f285c13092a869ff4edaaa71e0dfb03
BLAKE2b-256 c21d705241011ee72ba21fa57ff77c3db0772b1bfce3353ca5eb4b33f93d2e3a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page