Skip to main content

Transform code repositories into markdown-formatted strings ready for LLM prompting

Project description

   ___             _                    ___ 
  / __\  ___    __| |  ___    /\/\     /   \
 / /    / _ \  / _` | / _ \  /    \   / /\ /
/ /___ | (_) || (_| ||  __/ / /\/\ \ / /_// 
\____/  \___/  \__,_| \___| \/    \//___,' 

Ver. 0.0.3

CodeMD

🚀 Transform code files and repositories into markdown-formatted strings ready for LLM prompting and automatically copy to your clipboard. Perfect for seamless code-to-prompt workflow with ChatGPT, Claude, and other LLMs.

Tests License

📝 Overview

Tired of copying code files one by one? CodeMD instantly collects all relevant code in Markdown format and copies it to your clipboard - ready for ChatGPT, Claude, or any LLM.

Whether you need to process a single script or an entire codebase, CodeMD automatically:

  • Formats your code into LLM-friendly markdown
  • Preserves file structure and syntax highlighting
  • Estimates token usage for GPT models
  • Copies everything to your clipboard

Perfect for developers who want to:

  • Get AI assistance with code review
  • Ask LLMs about specific implementations
  • Document and explain codebases
  • Debug complex issues with AI help

No more manual copying and pasting - just run CodeMD and start chatting with your favorite LLM!

✨ Features

  • 🔍 Flexible Processing:
    • Single file processing
    • Recursive directory scanning
  • 🎯 Configurable Options:
    • Configurable file extensions
    • File and pattern exclusion support
    • Custom .gitignore support
  • 📊 Smart Output:
    • Markdown-formatted code blocks
    • Optional directory structure visualization
    • Token count estimation (with tiktoken)
    • Configurable output display
  • 📋 Convenience:
    • Simple command-line interface
    • Direct copy-to-clipboard support
    • Multiple output options

🎉 Recent Updates (0.0.3)

  • NEW: Single file processing support
  • NEW: Configurable output display (use --print to show output)
  • NEW: Repository structure visualization (auto-disabled for single files, or use --no-structure)
  • NEW: Automatic .gitignore support
    • Uses project's .gitignore by default
    • Custom .gitignore files via --gitignore
    • Disable with --ignore-gitignore

🚀 Installation

pip install codemd

or install from source!

git clone https://github.com/dotpyu/codemd.git
cd codemd
pip install -e .

📖 Usage

Command Line Interface

Single File Processing:

# Process a single file (no output by default)
codemd /path/to/script.py

# Process and display output
codemd /path/to/script.py --print

# Save to file
codemd /path/to/script.py -o output.md

Directory Processing:

# Basic directory scanning (no output by default)
codemd /path/to/your/code

# Show output in terminal
codemd /path/to/your/code --print

# Custom extensions and output file
codemd /path/to/your/code -e py,java,sql -o output.md

Pattern Exclusion:

codemd /path/to/your/code \
    --exclude-patterns "test_,debug_" \
    --exclude-extensions "test.py,spec.js"

.gitignore Configuration:

# Use custom gitignore files
codemd /path/to/your/code --gitignore .gitignore .custom-ignore

# Disable gitignore processing
codemd /path/to/your/code --ignore-gitignore

🤝 Contributing

Contributions are welcome! Feel free to open issues or submit pull requests.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

📄 License

Distributed under the Apache 2.0 License. See LICENSE for more information.


Made with ❤️ by Peilin

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

codemd-0.0.3.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

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

codemd-0.0.3-py3-none-any.whl (13.5 kB view details)

Uploaded Python 3

File details

Details for the file codemd-0.0.3.tar.gz.

File metadata

  • Download URL: codemd-0.0.3.tar.gz
  • Upload date:
  • Size: 15.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for codemd-0.0.3.tar.gz
Algorithm Hash digest
SHA256 6b07afa939cb5562e692809a2e8a5139cda1c8a4f058015faf3eb03d392b4d09
MD5 6bb7c54a54aa96c91333d7435553476b
BLAKE2b-256 4a485d86d0882b4bb06ee01a344b7f85cfc9289bd0d67c9d9f7be25b1712c43b

See more details on using hashes here.

Provenance

The following attestation bundles were made for codemd-0.0.3.tar.gz:

Publisher: publish.yml on dotpyu/codemd

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file codemd-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: codemd-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 13.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for codemd-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 2c2cfe0942d6234f3303838851c9aad3c9029dda2e967f301970fcf564f2c038
MD5 3e9d2758c26b7ee92aa787a73ffcc19a
BLAKE2b-256 15a8acb6b3020c489fbc6cb15e2c7e7631ed24a2dd2635f56a6deff16d974d35

See more details on using hashes here.

Provenance

The following attestation bundles were made for codemd-0.0.3-py3-none-any.whl:

Publisher: publish.yml on dotpyu/codemd

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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