Skip to main content

Generate a comprehensive Markdown document for any project directory via CLI

Project description

proj2md

License: MIT PyPI version Python Versions

proj2md is a command-line tool that generates a comprehensive Markdown document for any project directory. It traverses files, extracts structure and contents, and outputs a self-descriptive .md file ideal for LLM ingestion or static documentation.

Features

  • Recursive directory traversal with extension filtering
  • Optional ASCII tree view of the project structure
  • Automatic table of contents with anchors
  • YAML front-matter with project metadata (name, version, author, date)
  • Modes:
    • light: only tree + existing README
    • full: complete extraction of all files
  • List of dependencies from pyproject.toml or poetry
  • Customizable snippet length (--max-snippet-lines)
  • Exclusion patterns for files/folders (--exclude)
  • Easy installation via pip and entry-point proj2md

Installation

Requires Python 3.13 or higher.

Install from PyPI:

pip install proj2md

Or install locally from source:

git clone https://github.com/yourusername/proj2md.git
cd proj2md
pip install .

Usage

Basic usage (note that the actual file will be prefixed with generated_):

Note: regardless of the name provided via --output-file, the output file will be prefixed with generated_ to avoid self-inclusion.

Basic usage:

proj2md --input-dir ./my_project --output-file ./project.md

Available options:

--input-dir, -i PATH        Root directory (default: .)
--output-file, -o FILE      Output Markdown file (default: project.md)
--with-tree / --no-tree     Include project tree (default: with-tree)
--with-deps / --no-deps     Include dependencies list (default: with-deps)
--extensions, -e EXT1,EXT2  Comma-separated extensions (default: .py,.md,.yaml,.json)
--mode [light|full]         Extraction mode (default: full)
--max-snippet-lines N       Limit lines per file snippet
--exclude, -x PAT1,PAT2     Comma-separated ignore patterns

Examples

Full extraction with tree and dependencies:

proj2md -i ./src -o docs/project_full.md --with-tree --with-deps --mode full

Light mode (only tree + README):

proj2md -i ./src -o docs/project_light.md --no-deps --no-tree --mode light

Development

A Taskfile.yaml is provided to simplify common development workflows. Install the Task runner (task command), then run:

# Setup development environment (venv, dependencies, pre-commit)
task setup-dev

# Run the test suite
task run-tests

# Run code formatting and linting
task linter

# Clean build artifacts and cache
task clean

To list all available tasks:

task --list

Contributing

See CONTRIBUTING.md for guidelines on contributing.

Code of Conduct

This project adheres to the Contributor Covenant.

License

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

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

proj2md-0.1.0.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

proj2md-0.1.0-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file proj2md-0.1.0.tar.gz.

File metadata

  • Download URL: proj2md-0.1.0.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for proj2md-0.1.0.tar.gz
Algorithm Hash digest
SHA256 47cc869cc249c60f5715200217bb487152c1997749d3e15dd07a26efa332b10d
MD5 bf150a56d48cf0e5be66d95ee77120f6
BLAKE2b-256 d83999ce382de633a8477e5fb1d8d5d2c41dcee8490e04f1dc30b53c159a032c

See more details on using hashes here.

Provenance

The following attestation bundles were made for proj2md-0.1.0.tar.gz:

Publisher: release.yml on thibaud-perrin/proj2md

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file proj2md-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: proj2md-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 8.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for proj2md-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9c77dbe5125d3deef9fe2b3197a1aa1bff32a47e520918af8732d46d0d59a2f0
MD5 819304bac900c9d6d4b36610f67b0eaf
BLAKE2b-256 8f7d0b4ed9e598f87b8877a9a89949b34b5d409d143b9495b4fb338a494bebca

See more details on using hashes here.

Provenance

The following attestation bundles were made for proj2md-0.1.0-py3-none-any.whl:

Publisher: release.yml on thibaud-perrin/proj2md

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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