Skip to main content

AI-powered CLI tools (explain, script, visualize, config) using OpenAI models.

Project description

🧰 Codex CLI Studio

PyPI version License: MIT

A powerful suite of command-line tools powered by OpenAI models, built to supercharge productivity, learning, and automation for developers, DevOps, and students alike.


👀 Demo

See Codex CLI Studio in action! This animation shows basic usage of the explain, script, and visualize commands.

Codex CLI Studio Demo (Generated using asciinema and termtosvg)


🚀 Overview & Status

Codex CLI Studio is a modular set of CLI tools leveraging OpenAI's API.

Current Modules (v0.1.0):

  • explain: Explain code, shell commands, or file content.
  • script: Generate scripts (Bash, Python, PowerShell) from natural language.
  • visualize: Generate function call graphs for Python files (DOT/Image output).
  • config explain: Explain configuration files.
  • 🛠️ config edit: Modify configuration files (Planned).

🔌 Installation

Prerequisites:

  • Python 3.9+
  • pip
  • Graphviz (specifically the dot command) - Required only for rendering visualizations to image formats (png, svg, etc.) using the visualize command.
  • An OpenAI API Key.

Install using pip:

pip install codex-cli-studio

Set up your OpenAI API Key: The tool reads the API key from the OPENAI_API_KEY environment variable.

You can set it:

  • System-wide: Add export OPENAI_API_KEY='your_key_here' to your shell profile (.zshrc, .bashrc, etc.).
  • Per session: Run export OPENAI_API_KEY='your_key_here' in your terminal before using cstudio.
  • Using a .env file: Create a .env file in the directory where you run the cstudio command and add the line OPENAI_API_KEY='your_key_here'.

✨ Usage

After installation, use the cstudio command:

# General help
cstudio --help

# Explain a code snippet
cstudio explain 'import sys; print(sys.argv[1])' --lang en

# Explain a file in detail
cstudio explain path/to/your/code.py --detail detailed

# Generate a Python script
cstudio script "read lines from data.txt and print them numbered" -t python

# Generate a bash script (dry run only)
cstudio script "delete all *.tmp files in /tmp" --dry-run

# Visualize a Python file, saving as PNG
cstudio visualize path/to/visualize.py -f png -o visualize_graph.png

# Explain a YAML config file
cstudio config explain path/to/config.yaml

🛠️ Module Details

explain

Explains code snippets, shell commands, or file content.

  • Supports various languages (auto-detected by AI).
  • Options: --detail basic|detailed, --lang <language_code>.

script

Generates executable scripts from natural language tasks.

  • Supports: Bash, Python, PowerShell.
  • Options: --type <bash|python|powershell>, --dry-run (only displays script).

visualize

Generates function call graphs for Python files.

  • Input: Python file (.py).
  • Output: Graphviz DOT (.gv, .dot) or rendered image (.png, .svg, .pdf, etc.).
  • Requires Graphviz (dot command) for image rendering.
  • Options: --output <path>, --format <format>.

config explain

Explains various configuration files (YAML, INI, Dockerfile, etc.).

  • Input: Path to configuration file.

config edit 🛠️ (Planned)

Modify configuration files using natural language instructions.


🌍 Why It Matters

  • Educational: Quickly understand unfamiliar code, commands, or configs.
  • Productive: Automate script generation and explanations, reducing boilerplate and search time.
  • 🔧 Extensible: Modular design allows for adding new commands and capabilities.
  • 🌱 Open Source: Community contributions are welcome!

📦 Built With

  • Python 3.9+
  • OpenAI API (gpt-4o or other models)
  • Typer - for building the CLI interface.
  • Rich - for beautiful terminal output.
  • python-dotenv - for managing environment variables.
  • Graphviz (Python library) - for generating DOT graph descriptions.
  • Standard Python libraries (ast, subprocess, shutil, etc.)

🔮 Roadmap / Coming Soon

  • Testing: Increase test coverage, especially for edge cases and options.
  • Error Handling: Improve robustness and user feedback on errors.
  • config edit: Implement the configuration editing functionality.
  • visualize Enhancements: Options to exclude nodes (builtins), different layouts.
  • More Modules? test generation, translate code? (Open to ideas!)
  • Configuration: Centralized config file (e.g., ~/.config/codex-cli-studio/config.toml).
  • PyPI Release: Package and publish for easy pip install.
  • IDE Integration: VS Code plugin?

🤝 Contributing

Contributions, issues, and feature requests are welcome! Feel free to check issues page.

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

📄 License

Distributed under the MIT License. See LICENSE file for more information.


→ Apply this to real-world workflows. Use AI like magic — right from your terminal.

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

codex_cli_studio-0.1.1.tar.gz (22.6 kB view details)

Uploaded Source

Built Distribution

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

codex_cli_studio-0.1.1-py3-none-any.whl (17.6 kB view details)

Uploaded Python 3

File details

Details for the file codex_cli_studio-0.1.1.tar.gz.

File metadata

  • Download URL: codex_cli_studio-0.1.1.tar.gz
  • Upload date:
  • Size: 22.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for codex_cli_studio-0.1.1.tar.gz
Algorithm Hash digest
SHA256 92c89c80bf5213b2a61fc7bbbd80cbdc3f0334a28a43d7af82ae9dd0784a6723
MD5 c65183fedce48b3552ff5942c3e8587f
BLAKE2b-256 2ffb5fd321b4fd5951e567360adc73dd05f6d642f756649224da1bab995e6e0f

See more details on using hashes here.

File details

Details for the file codex_cli_studio-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for codex_cli_studio-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 91dca6d5e60b1d28facc494372e1a3936585abb21a24012bbff110925405cc22
MD5 050eddee79b3fda016f479b0d519b433
BLAKE2b-256 97044fc75e211fd0e46373633cccaeac9a63b36b1c9388bd6ae14cc38aab8cbd

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