Skip to main content

Copy any repository into the clipboard. And get the token count.

Project description

repo2string

PyPI version Python Versions License: MIT Downloads CI codecov

repo2string is a Python package and CLI tool that gathers all files in a repository (or any folder), excluding ignored files as specified by a .gitignore (if present), and concatenates them into a single string. This is useful for copying the entire codebase as a context to large language models (LLMs) like ChatGPT.

Features:

  • Recursively traverse directories.
  • Skip files listed in .gitignore (if present) or skip only .git if no .gitignore exists.
  • Generate a file tree (with absolute paths).
  • Include the contents of all non-ignored files.
  • Copy all text to your clipboard automatically.
  • Token counting: Displays the token count of the entire prompt.
  • Verbose mode (-v or --verbose): Also prints the token counts per file, sorted from highest to lowest.

Installation

You can install repo2string directly from PyPI:

pip install repo2string

Or install from source:

git clone https://github.com/szulcmaciej/repo2string.git
cd repo2string
pip install .

Development Setup

To set up the development environment:

  1. Clone the repository:

    git clone https://github.com/szulcmaciej/repo2string.git
    cd repo2string
    
  2. Create and activate a virtual environment:

    python -m venv venv
    source venv/bin/activate  # On Windows: venv\Scripts\activate
    
  3. Install the package in editable mode with development dependencies:

    pip install -e ".[test]"
    
  4. Install pre-commit hooks:

    pre-commit install
    

The pre-commit hooks will:

  • Run Ruff for linting and auto-formatting
  • Run pytest to ensure all tests pass
  • Block commits if any checks fail

To run tests manually:

pytest

Usage

repo2string [PATH] [--verbose]
  • PATH is optional; defaults to . (current directory).
  • --verbose or -v prints a token-count summary per file (descending).

Example:

repo2string /path/to/myproject --verbose

You will see console output summarizing the total token count, plus a per-file token breakdown if in verbose mode. The entire text is copied to your clipboard.

Now you can paste the combined repo data into ChatGPT or another LLM interface to work on your code with maximum context.

License

MIT

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

repo2string-0.2.0.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

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

repo2string-0.2.0-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file repo2string-0.2.0.tar.gz.

File metadata

  • Download URL: repo2string-0.2.0.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for repo2string-0.2.0.tar.gz
Algorithm Hash digest
SHA256 49a7a099a5b06738d44b737af584f435fe9728ad2682754dcfb30a366634e96b
MD5 73d93f604df63d1863e58f94339352f4
BLAKE2b-256 87aed836a0990d5c02d91cee36a17952ecdfdbce788861fe1f9554009cff494b

See more details on using hashes here.

File details

Details for the file repo2string-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: repo2string-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 5.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for repo2string-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 56d4ef1cde915ba0259aa249c01574f5231d95241423174cdd6a9b90191d0919
MD5 4935e5866cc9f8db65ce6edb960953a8
BLAKE2b-256 78cb4ac286d6f2c7e6975318efa7d4fd415c3c94104c0e163fafc8c0f1b7b20e

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