uncoil
is a command-line tool designed to explore and recursively unfurl the contents of a directory into a single output, either printed to the terminal or saved to a file. It has an option to skip certain file extensions or entire subdirectories, as it works best with text-based files.
It will produce tree visualization of directories and files and will reveal the contents of files not specified to be skipped.
This can be useful for navigating large projects, quickly summarizing as well as thoroughly revealing the structure and contents of a project.
It may be useful for providing context of a codebase to a Large Language Model (LLM).
uncoil
can be installed using pip directly from the GitHub repository or by cloning the repo. Choose the method that best suits your needs.
First, create and activate a virtual environment. For example, with conda
, run:
conda create -n myenv -y
conda activate myenv
To install the latest version of uncoil
directly from GitHub, run:
pip install git+ssh://git@github.com/thompsonmj/uncoil.git
Or to install a pinned release version, such as v1.1.1, run:
pip install git+ssh://git@github.com/thompsonmj/uncoil.git@v1.1.1
uncoil -d <directory> [-o <output_file>] [-x <extensions_to_skip,dirs_to_skip>]
usage: uncoil [-h] -d DIRECTORY [-o OUTPUT_FILE] [-x EXCLUDE] [-t TAG]
Process a directory and unfurl its contents.
options:
-h, --help show this help message and exit
-d DIRECTORY, --directory DIRECTORY
Directory to process.
-o OUTPUT_FILE, --output_file OUTPUT_FILE
Output file to redirect output into.
-x EXCLUDE, --exclude EXCLUDE
Comma-separated list of file extensions or directories to skip.
-t TAG, --tag TAG Optional tag to wrap around output. Enter 'none' for no tag.
- Print the unfiltered structure of a directory to the console:
uncoil -d directory
- Print the structure of a directory to the console, skipping certain extensions and subdirectories:
uncoil -d directory -x .log,.tmp,.git
- Save the unfiltered structure of a directory to a file:
uncoil -d directory -o output.txt
- Save the structure of a directory to a file, skipping certain extensions and subdirectories:
uncoil -d directory -o output.txt -x .log,.tmp,.git
- Save the unfiltered structure of a directory to a file, wrapping the output in a custom tag:
uncoil -d directory -o output.txt -t "my_project"
For example, see the examples/ directory for output of the following command run on this uncoil
repository itself:
uncoil -d . \
-o examples/uncoil.txt \
-x .git,.gitignore,LICENSE,.venv,.ruff_cache,__pycache__,.pytest_cache,examples \
-t uncoil_codebase