Skip to content

thompsonmj/uncoil

Repository files navigation

uncoil

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.

By default, folders and files that are suspected to provide no useful information (e.g., .git, .venv, __pycache__, etc.) are hard skipped, i.e. they are not included in the tree, and their contents are not revealed. Data folders and files which would not provide useful information through their contents but possibly through their presence (e.g. .jpg, .tar, etc.) are soft skipped, i.e. they are shown in the tree, but their contents are not revealed.

Using the -x option, you can specify additional file extensions or directories to hard skip.

The package handles Jupyter notebooks by converting to text using jupytext in the output without affecting the contents of the notebook or adding any files to the directory.

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).

Installation

To install the latest version of uncoil, run:

pip install uncoil

Usage

uncoil -d <directory> [-o <output_file>] [-x <extensions_to_skip,dirs_to_skip>] [-t <tag>]

Options

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.

Examples

  1. Print the unfiltered structure of a directory to the console:
uncoil -d directory
  1. Print the structure of a directory to the console, skipping certain extensions and subdirectories:
uncoil -d directory -x .log,.tmp,.git
  1. Save the unfiltered structure of a directory to a file:
uncoil -d directory -o output.txt
  1. Save the structure of a directory to a file, skipping certain extensions and subdirectories:
uncoil -d directory -o output.txt -x .log,.tmp,.git
  1. 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 LICENSE \
-t uncoil_codebase

Development

To develop the package further:

  1. Clone the repository and create a branch
  2. Install with dev dependencies:
pip install -e ".[dev]"
  1. Install pre-commit hook
pre-commit install
pre-commit autoupdate # optionally update
  1. Run tests:
pytest

About

A Python package to reveal the structure and contents of a directory.

Resources

License

Stars

Watchers

Forks

Packages

No packages published