Skip to main content

Markdown tools for modular workflows and content management.

Project description

Markitecture Logo

Markitecture

The Architecture of Better Documentation.

Tools for modular Markdown workflows and content management.

Documentation · Contribute · Report Bug · Request Feature

separator

What is Markitecture?

Markitecture is a comprehensive Python toolkit designed to streamline your Markdown workflow. Whether you're managing documentation, writing technical content, or maintaining a knowledge base, Markitecture provides essential utilities to make working with Markdown files easier and more efficient.

Key Features

  • Text Splitting: Break down large Markdown files into manageable sections based on headings or custom rules.
  • Link Management: Convert between inline and reference-style links, validate URLs, and identify broken links.
  • Content Analysis: Analyze document structure, extract metadata, and ensure consistent formatting.
  • Documentation Tools: Generate configurations for static site generators like MkDocs.

Quick Start

Installation

Install from PyPI using your preferred package manager.

 pip

Use pip (recommended for most users):

pip install -U markitecture

 pipx

Install in an isolated environment with pipx:

 pipx install markitecture

 uv

For the fastest installation use uv:

 uv tool install markitecture

Using the CLI

Text Splitting

Split large Markdown files into smaller, organized sections:

markitect \
    --split.i tests/data/readme-ai.md \
    --split.o examples/split-sections-h2

Link Validation

Check for broken links in your documentation:

markitect --check-links.input tests/data/pydantic.md

In your terminal, you'll see a summary of the results:

Markdown Link Check Results

┏━━━━━━━━┳━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━┓
┃ Status ┃ Line ┃ Link                                                                              ┃ Error    ┃
┡━━━━━━━━╇━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━┩
│ ✓      │ 2    │ https://img.shields.io/github/actions/workflow/status/pydantic/pydantic/ci.yml?b… │          │
│ ✓      │ 3    │ https://coverage-badge.samuelcolvin.workers.dev/pydantic/pydantic.svg             │          │
│ ✓      │ 4    │ https://img.shields.io/pypi/v/pydantic.svg                                        │          │
│ ✓      │ 5    │ https://img.shields.io/conda/v/conda-forge/pydantic.svg                           │          │
│ ✓      │ 6    │ https://static.pepy.tech/badge/pydantic/month                                     │          │
│ ✓      │ 7    │ https://img.shields.io/pypi/pyversions/pydantic.svg                               │          │
│ ✓      │ 8    │ https://img.shields.io/github/license/pydantic/pydantic.svg                       │          │
│ ✓      │ 9    │ https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/pydantic/p… │          │
│ ✓      │ 18   │ https://pydantic.dev/articles/logfire-announcement                                │          │
│ ✓      │ 24   │ https://docs.pydantic.dev/                                                        │          │
│ ✓      │ 24   │ https://github.com/pydantic/pydantic/tree/1.10.X-fixes                            │          │
│ ✓      │ 28   │ https://docs.pydantic.dev/                                                        │          │
│ 𝗫      │ 34   │ https://docs.pydantic.dev/install/invalid-link                                    │ HTTP 404 │
└────────┴──────┴───────────────────────────────────────────────────────────────────────────────────┴──────────┘

Summary: 1 broken links out of 13 total links.

Reference Link Conversion

In Markdown, reference-style links let you write cleaner text by keeping URLs in a reference section - think footnotes for the web.

To convert inline links to reference-style links:

markitect \
    --reflinks.input tests/data/pydantic.md \
    --reflinks.output with_refs.md

Static Site Configuration Generation

Generate a MkDocs configuration (mkdocs.yml) from a given Markdown file.

  1. Split the Markdown file into sections:

    markitect \
        --split.i tests/data/readme-ai.md \
        --split.o examples/split-sections-h2
    
  2. Generate the MkDocs configuration:

    markitect \
        --mkdocs.dir examples/split-sections-h2 \
        --mkdocs.site-name "MyDocsSite"
    

See additional example and usage details in the here.


Roadmap

  • Support for additional documentation formats (e.g., reStructuredText, HTML)
  • Enhanced link management utilities
  • Improved content analysis features
  • Integration with more static site generators
  • Plugin system for custom utilities
  • More intuitive CLI commands and options

Contributing

Contributions are welcome! Whether it's bug reports, feature requests, or code contributions, please feel free to:

  • Open an issue
  • Submit a pull request
  • Improve documentation, write tutorials, etc.
  • Share your feedback and suggestions

License

Copyright © 2024 - 2025 Markitecture All rights reserved.
Released under the MIT license.

Copyright © 2024-2025 Markitecture.
Released under the MIT license.

Thematic Break

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

markitecture-0.2.32.tar.gz (257.2 kB view details)

Uploaded Source

Built Distribution

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

markitecture-0.2.32-py3-none-any.whl (42.1 kB view details)

Uploaded Python 3

File details

Details for the file markitecture-0.2.32.tar.gz.

File metadata

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

File hashes

Hashes for markitecture-0.2.32.tar.gz
Algorithm Hash digest
SHA256 8566de2e00be358c0b22ff6b3e04c548426a4b56288d0519e34a05366da8fb70
MD5 45253e3e3a101622da2f7f6566c45f21
BLAKE2b-256 8c8dc2cf0dd1f7f3ce915c950bb823278f5596b88ae3bb73ae1a6a55ce90b8f7

See more details on using hashes here.

Provenance

The following attestation bundles were made for markitecture-0.2.32.tar.gz:

Publisher: ci.yml on eli64s/markitecture

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

File details

Details for the file markitecture-0.2.32-py3-none-any.whl.

File metadata

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

File hashes

Hashes for markitecture-0.2.32-py3-none-any.whl
Algorithm Hash digest
SHA256 2dd72b404b929efb3e60f49717b9f6791c107f6689fef9825b2b352ac0c0431d
MD5 086ccefd69553f3a517d86ace44f672b
BLAKE2b-256 1e79a0b12b1f638803b1f98d44cf893c6f26a05ba6b563c7b4be3aea51da5d59

See more details on using hashes here.

Provenance

The following attestation bundles were made for markitecture-0.2.32-py3-none-any.whl:

Publisher: ci.yml on eli64s/markitecture

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