#text-file #repository #github #single #convert #snapshot

app gitsnap

A tool to take snapshots of GitHub repositories in a single text file

1 unstable release

0.1.0 Jan 28, 2025

#289 in Debugging

Download history 23/week @ 2025-01-22 83/week @ 2025-01-29

106 downloads per month

MIT license

16KB
366 lines

gitsnap

gitsnap is a CLI tool to take snapshots of GitHub repositories and convert them into readable text files.

Description

gitsnap allows you to download a GitHub repository and convert its contents into a single text file. You can specify a file size threshold to skip large files or include all files regardless of size. The tool also supports debug mode for verbose logging.

Installation

To install gitsnap, you need to have Rust and Cargo installed. You can install Rust and Cargo from rustup.rs.

Clone the repository and build the project:

git clone <https://github.com/flaviodelgrosso/GitSnap.git>
cd gitsnap
cargo build --release

Usage

Run the gitsnap command with the required arguments:

gitsnap <repository> [OPTIONS]

Arguments

  • repository: The GitHub repository URL or user/repo format (e.g., 'user/repo' or 'https://github.com/user/repo'). This argument is required.

Options

  • -o, --output <FILE>: Specify the output file path (defaults to repo_name.txt).
  • -t, --threshold <MB>: Set file size threshold in MB for text conversion (default: 0.1 MB). Files larger than this are skipped unless --include-all is used.
  • --include-all: Include all files, regardless of size or type. Overrides the threshold.
  • --debug: Enable debug mode with verbose logging.

Example

gitsnap user/repo -o output.txt -t 1.0 --debug

This command will download the user/repo repository, process files up to 1.0 MB, and save the output to output.txt with debug mode enabled.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Dependencies

~8–19MB
~271K SLoC