Skip to main content

cod8a is a code documentation and visualization tool for Python and .NET projects

Project description

cod8a

cod8a pronounced codetta, is a code documentation and visualization tool for Python and .NET projects.

Installation

Prerequisites

From PyPI

Install cod8a directly using pip:

pip install cod8a

Usage

The tool uses a CLI interface to analyze code and generate mermaid diagrams.

UML Diagrams

Generate Mermaid-compatible diagrams (Class, Sequence, Flowchart):

# General syntax
cod8a uml -p <path_to_source> -d <diagram_type>

# Generate a class diagram (default)
cod8a uml -p <path_to_source>

# Generate a sequence diagram
cod8a uml -p <path_to_source> -d sequence

# Generate a flowchart
cod8a uml -p <path_to_source> -d flow

# Summarize a large project (omit fields/methods)
cod8a uml -p <path_to_source> --summarize

# Force full diagram details for a large file
cod8a uml -p <path_to_source> --no-summarize

Diagram Type Options:

  • Class: class, c
  • Sequence: sequence, seq, s
  • Flowchart: flowchart, flow, f

Visualizing Diagrams

The generated .mmd files can be visualized using several tools:

  • Mermaid Live Editor: Simply copy and paste the generated output into the editor to view and export the diagram as an image (SVG, PNG).
  • VS Code: Install the Mermaid Editor or Markdown Mermaid Preview extension to see live previews directly in your IDE.
  • GitHub: GitHub natively renders Mermaid diagrams in Markdown files.

Samples

Below are detailed example Mermaid diagrams generated by cod8a based on its own src/cod8a/models/models.py file:

CLI Options

  • -p, --path: Path to the file or directory to analyze.
  • -d, --diagram: Type of diagram to generate (default: class).
  • -o, --output: Output file path (saves as .mmd).
  • -s, --summarize / --no-summarize: Enable or disable diagram summarization. When enabled, details like fields and methods are omitted (useful for large files). Defaults to auto-summarize for large files.

Documentation (In development)

Note: This feature is currently in development.

Generate Markdown documentation from code structure:

# Not yet implemented
cod8a doc -p <path_to_source>

Features

  • Mermaid Integration: Generates high-quality Mermaid.js diagrams for visualization.
    • Supported Diagrams: Class, Sequence, and Flowchart diagrams.
  • C# Support: Uses a Roslyn-based analyzer targeting .NET 10.0 to extract deep structural information.
  • Python Support: Uses AST-based parsing for Python files.
  • Markdown Documentation (TODO): Detailed markdown generation for code documentation is currently in development.

Development

Setup

  1. Fork the repository on GitHub.
  2. Clone your fork:
git clone https://github.com/yourusername/cod8a.git
cd cod8a

Development Options

1. Local Setup

  1. Install Python dependencies:

Using Poetry (recommended):

poetry install
  1. Optional: Ensure .NET 10.0 is installed (if documenting C#)
dotnet --version

2. VS Code Dev Container (Recommended)

If you use VS Code, you can skip the local setup by using the provided Dev Container. It comes pre-configured with Python 3.13, .NET 10.0, and Poetry.

  • Simply open the project in VS Code and click "Reopen in Container" when prompted.

3. Docker

You can also run cod8a as a standalone container without installing any dependencies locally:

# Build the image
docker build -t cod8a .

# Run the tool
docker run -v $(pwd):/app/data cod8a uml -p /app/data/src

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

cod8a-0.3.1.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

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

cod8a-0.3.1-py3-none-any.whl (28.8 kB view details)

Uploaded Python 3

File details

Details for the file cod8a-0.3.1.tar.gz.

File metadata

  • Download URL: cod8a-0.3.1.tar.gz
  • Upload date:
  • Size: 21.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cod8a-0.3.1.tar.gz
Algorithm Hash digest
SHA256 fade1ec7db0b6f573c5ac839e64828f895a2f060b5d59cc3b52783bff4c9a1c5
MD5 a3256f78622984a25afd0a08a7361769
BLAKE2b-256 f67135e13ade7f77f20dfb6ae7ed7b58570efdeaec8c817c8ffecbd69f9d95a1

See more details on using hashes here.

Provenance

The following attestation bundles were made for cod8a-0.3.1.tar.gz:

Publisher: pypi-publish.yml on marietta-a/cod8a

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

File details

Details for the file cod8a-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: cod8a-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 28.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cod8a-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7be38597cfba7b07ecad581bf21bc6c5501e3cf6646af1b7a1c57eee3709abd9
MD5 f13f700a0d614060a898ced9bc1a2022
BLAKE2b-256 c2c76e24c88ae2f3670627427981a270a69bc8ca007e8759a6dacb32f57a6f29

See more details on using hashes here.

Provenance

The following attestation bundles were made for cod8a-0.3.1-py3-none-any.whl:

Publisher: pypi-publish.yml on marietta-a/cod8a

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