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.4.tar.gz (6.7 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.4-py3-none-any.whl (5.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: repo2string-0.2.4.tar.gz
  • Upload date:
  • Size: 6.7 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.4.tar.gz
Algorithm Hash digest
SHA256 95ff37a81199e7bb5eebbd89e7b5d8522edcb7b59dc4df7f376e53a6ae0f6d6d
MD5 b12c75704a224ae6348f9fc644ad873b
BLAKE2b-256 67aa8954fd5bdebdd619a3abf8fe09bc1fc557e000a7103295d5268355202b40

See more details on using hashes here.

File details

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

File metadata

  • Download URL: repo2string-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 5.4 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 ab2b13316725f2bcc07f8c2d67fefbad997bb7950087d55dd83be5d43adab32e
MD5 6a5ec0169bbb3a61898db7f33e15599f
BLAKE2b-256 5d3a672dd29cbb9c3dec5c2e704ed5ddde71906cbfa7d23d94f6a625db26f438

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