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 .

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.

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

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.3.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.3-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: repo2string-0.2.3.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.3.tar.gz
Algorithm Hash digest
SHA256 22478d90c197de3cb8fdf219b115501b80f92849649aa5faeec34b35e780fe28
MD5 ce30742b46d59853a42ee38de948636b
BLAKE2b-256 dd98dc4f9c329676052f0ddebe5cc00a87355c030fbca19cf0b3ac292f036572

See more details on using hashes here.

File details

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

File metadata

  • Download URL: repo2string-0.2.3-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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f48a001a133686fcf15ffd023ea39d0d3ef25c515b922259118d4b6326006055
MD5 72f90ccf83f47c2b4f5767da071945e9
BLAKE2b-256 83b7a72f6b491b9c98b0d4f890e0a461c6b625f56e193f71c16df748b0c78cbe

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