Ultra-fast MDX rendering engine powered by Rust.
Project description
omni-mdx
A blazingly fast, headless MDX engine for Python, powered by a native Rust core.
omni-mdx provides a high-performance bridge between the pulldown-cmark Rust parser and native Python applications. It parses MDX (Markdown + JSX) into a deeply manipulable Abstract Syntax Tree (AST) and offers zero-dependency native rendering solutions for both the Web (HTML/KaTeX) and Desktop (PyQt5/Matplotlib).
⚡ Key Features
- 🚀 Blazing Fast: Parsing is handled by a pre-compiled Rust binary. Experience performance up to 10x faster than pure Python parsers.
- 🧠 Headless AST: Manipulate Markdown and JSX tags as pure Python objects (
AstNode). Perfect for data extraction and content analysis. - 🖼️ Zero-HTML Desktop Rendering: Render rich text, complex layouts, and math equations natively in PyQt5 without the overhead of heavy WebEngine/Chromium components.
- 📐 Universal Math Support:
- Web: Generates
data-mathattributes compatible with KaTeX. - Desktop: Generates high-quality native images via Matplotlib with automatic Unicode fallback.
- Web: Generates
- 📦 Fat Wheel Distribution: The Rust binary is bundled directly into the Python package. No Rust toolchain required for end-users.
📦 Installation
pip install omni-mdx
# Optional: Required for high-quality Desktop math rendering
pip install matplotlib PyQt5
🛠️ Quick Start
1. Parsing MDX to AST
The core strength of omni-mdx is transforming raw text into a structured, searchable tree.
import omni_mdx
mdx_content = r"""
# Physics 101
The kinetic energy is defined as:
$$\zeta(s) = \sum_{n=1}^\infty \frac{1}{n^s}$$
<Note type="warning">Check your units!</Note>
"""
# Parse the text into a list of AstNode objects
nodes = omni_mdx.parse(mdx_content)
# Search the AST for specific elements
math_blocks = [n for n in nodes if n.node_type == "BlockMath"]
if math_blocks:
print(f"Formula found: {math_blocks[0].content}")
# Output: \zeta(s) = \sum_{n=1}^\infty \frac{1}{n^s}
2. Web Rendering (HTML)
Generate clean, standards-compliant HTML for FastAPI, Flask, or static site generators.
from omni_mdx import render_html, parse
nodes = parse("<Speaker name='Leon'>Welcome to the show.</Speaker>")
# Register custom rendering logic for JSX components
def render_speaker(node, ctx):
name = node.attr_text("name")
return f'<div class="speaker-tag"><b>{name}:</b> {node.text_content()}</div>'
html_output = render_html(nodes, components={"Speaker": render_speaker})
3. Native Desktop Rendering (PyQt5)
Render MDX content directly into native Qt Widgets. No browser engine needed.
from PyQt5.QtWidgets import QScrollArea
from omni_mdx.qt_renderer import QtRenderer
# 1. Parse content
nodes = omni_mdx.parse("# Hello Native!")
# 2. Render to Widget
renderer = QtRenderer()
content_widget = renderer.render(nodes)
# 3. Add to your UI (using a ScrollArea is recommended)
scroll = QScrollArea()
scroll.setWidget(content_widget)
scroll.setWidgetResizable(True)
🧠 Advanced AST Manipulation
Because omni-mdx generates a typed AstNode tree, it is an ideal tool for large-scale text analysis, TTS (Text-To-Speech) dataset generation, or automated content moderation.
from omni_mdx import parse
script = """
<Speaker name="Dr. Aris" voiceId="v2">
We must look closer at the probability wave.
</Speaker>
<Speaker name="Leon" voiceId="v1">
Are you certain?
</Speaker>
"""
nodes = parse(script)
# Extract dialogue for dataset generation
dataset = []
for node in nodes:
if node.node_type == "Speaker":
dataset.append({
"character": node.attr_text("name"),
"voice_profile": node.attr_text("voiceId"),
"text": node.text_content().strip()
})
print(dataset[0]["text"]) # "We must look closer at the probability wave."
🏗️ Architecture
| Module | Description |
|---|---|
core_interface |
Bridge to the native Rust _core binary. |
renderer |
High-performance HTML generator. |
qt_renderer |
Native PyQt5 layout engine (uses a custom FlowLayout). |
math_render |
LaTeX logic: Unicode mapping & Matplotlib integration. |
🤝 Contributing
This package is part of the TOAQ open-source ecosystem.
- Core Engine (Rust): TOAQ-oss/omni-mdx-core
- Bug Tracker: GitHub Issues
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file omni_mdx-1.0.0.dev1775544344-cp313-cp313-win_amd64.whl.
File metadata
- Download URL: omni_mdx-1.0.0.dev1775544344-cp313-cp313-win_amd64.whl
- Upload date:
- Size: 630.8 kB
- Tags: CPython 3.13, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f4192a2cd7a31d64064ffc7ca2ecf98d803121880ef72c4c0e03f99482895605
|
|
| MD5 |
b1a5e43133d673fdb8a1520bc1b0e70b
|
|
| BLAKE2b-256 |
969256ba857988cbf47f34ab44a546a54969c550abf22be60853086bf359a761
|
Provenance
The following attestation bundles were made for omni_mdx-1.0.0.dev1775544344-cp313-cp313-win_amd64.whl:
Publisher:
publish-python.yml on TOAQ-oss/omni-mdx-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
omni_mdx-1.0.0.dev1775544344-cp313-cp313-win_amd64.whl -
Subject digest:
f4192a2cd7a31d64064ffc7ca2ecf98d803121880ef72c4c0e03f99482895605 - Sigstore transparency entry: 1246082678
- Sigstore integration time:
-
Permalink:
TOAQ-oss/omni-mdx-core@063144dab8527c1393bef56c8a7d13d6e7fd9c64 -
Branch / Tag:
refs/heads/canary - Owner: https://github.com/TOAQ-oss
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python.yml@063144dab8527c1393bef56c8a7d13d6e7fd9c64 -
Trigger Event:
push
-
Statement type:
File details
Details for the file omni_mdx-1.0.0.dev1775544344-cp313-cp313-manylinux_2_34_x86_64.whl.
File metadata
- Download URL: omni_mdx-1.0.0.dev1775544344-cp313-cp313-manylinux_2_34_x86_64.whl
- Upload date:
- Size: 815.3 kB
- Tags: CPython 3.13, manylinux: glibc 2.34+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ac1aaa71a1083d0dc453b96272a97afcfeabf53a63badb4842d4aa6f64934216
|
|
| MD5 |
671d4eb91ac319f5631ea65c78d2386c
|
|
| BLAKE2b-256 |
67d54e256898d26c5aeff92e5a7d40c47f1ac04eeb9f4b98666e449637368ff1
|
Provenance
The following attestation bundles were made for omni_mdx-1.0.0.dev1775544344-cp313-cp313-manylinux_2_34_x86_64.whl:
Publisher:
publish-python.yml on TOAQ-oss/omni-mdx-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
omni_mdx-1.0.0.dev1775544344-cp313-cp313-manylinux_2_34_x86_64.whl -
Subject digest:
ac1aaa71a1083d0dc453b96272a97afcfeabf53a63badb4842d4aa6f64934216 - Sigstore transparency entry: 1246082685
- Sigstore integration time:
-
Permalink:
TOAQ-oss/omni-mdx-core@063144dab8527c1393bef56c8a7d13d6e7fd9c64 -
Branch / Tag:
refs/heads/canary - Owner: https://github.com/TOAQ-oss
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python.yml@063144dab8527c1393bef56c8a7d13d6e7fd9c64 -
Trigger Event:
push
-
Statement type:
File details
Details for the file omni_mdx-1.0.0.dev1775544344-cp313-cp313-macosx_11_0_arm64.whl.
File metadata
- Download URL: omni_mdx-1.0.0.dev1775544344-cp313-cp313-macosx_11_0_arm64.whl
- Upload date:
- Size: 712.1 kB
- Tags: CPython 3.13, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ccc68230403538a5b26ae4eb1b32952869b01cdcc8eb9bd832bbdd62d2f8e9ba
|
|
| MD5 |
00c55301fe7e0f02082f2c34aadfe476
|
|
| BLAKE2b-256 |
c011bca837bc729932a138c84f42bd088b0e4aec384ca53c383f17feaddf35f5
|
Provenance
The following attestation bundles were made for omni_mdx-1.0.0.dev1775544344-cp313-cp313-macosx_11_0_arm64.whl:
Publisher:
publish-python.yml on TOAQ-oss/omni-mdx-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
omni_mdx-1.0.0.dev1775544344-cp313-cp313-macosx_11_0_arm64.whl -
Subject digest:
ccc68230403538a5b26ae4eb1b32952869b01cdcc8eb9bd832bbdd62d2f8e9ba - Sigstore transparency entry: 1246082682
- Sigstore integration time:
-
Permalink:
TOAQ-oss/omni-mdx-core@063144dab8527c1393bef56c8a7d13d6e7fd9c64 -
Branch / Tag:
refs/heads/canary - Owner: https://github.com/TOAQ-oss
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python.yml@063144dab8527c1393bef56c8a7d13d6e7fd9c64 -
Trigger Event:
push
-
Statement type: