Convert Markdown to BBCode using a custom Mistune renderer.
Project description
md2bbcode
A wrapper and plugin for Mistune. It converts most GitHub-flavored Markdown to Xenforo-flavored BBCode.
[!TIP] Custom BBCodes made for RedGuides are included in
bb_codes.xml, import the ones you want in your Xenforo installation atadmin.php?bb-codes. Some custom BBCodes include css, which you can split off to your extra.css template for more efficiency.
[!NOTE]
This project is made with LLM assistance.
Usage
After installation, you can use md2bbcode from the command line:
md2bbcode README.md
If the markdown includes relative images or other assets, you can use the --domain flag to prepend a domain to the relative URLs:
md2bbcode README.md --domain https://raw.githubusercontent.com/RedGuides/md2bbcode/main/
You can also use the package in your Python project:
from md2bbcode.main import process_readme
# Your Markdown content
markdown_text = "# Hell World"
# Optional domain to prepend to relative URLs
domain = 'https://raw.githubusercontent.com/yourusername/yourrepo/main/'
# Convert Markdown to BBCode
bbcode_output = process_readme(markdown_text, domain=domain)
# Output the BBCode
print(bbcode_output)
Debug Mode
You can use the --debug flag to save intermediate results to files for debugging:
md2bbcode README.md --debug
Development
If you want to contribute to md2bbcode or set up a development environment, follow these steps:
-
Clone the repository:
git clone https://github.com/RedGuides/md2bbcode.git cd md2bbcode
-
Create a development environment and install dependencies:
hatch env create
-
Activate the development environment:
hatch shell
renderers/bbcode.py
The custom plugin for Mistune, which converts AST to bbcode.[^1]
[^1]: Mistune does not convert Markdown HTML to AST, hence the need for html2bbcode.
Additional Tools
html2bbcode
Converts most HTML tags typically allowed in Github Flavored Markdown to BBCode.[^2]
[^2]: Currently used for post-processing mistune output. Reference: https://github.github.com/gfm/#raw-html
html2bbcode input_file.html
md2ast
For debugging Mistune's renderer, converts a Markdown file to AST (JSON format).
md2ast input.md output.json
Features Test
Here are a few GitHub-flavored Markdown features so you can use this README.md for testing, including the table:
| Feature | Markdown | Rendered |
|---|---|---|
| Bold | **text** |
bold |
| Italic | *text* |
italic |
| Strikethrough | ~~text~~ |
|
| Code | `code` |
inline |
| Link | [text](url) |
example |
| Superscript | <sup>2</sup> |
E=mc2 |
| Subscript | <sub>2</sub> |
H2O |
HTML spoiler (details/summary)
html2bbcode test. This is hidden content. Water is H2O.
Font tag inside details size 3 Arial red
Inline style inside details green times new roman strikethrough italic bold underline
This is a quote by John Doe
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
Built Distribution
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 md2bbcode-1.1.0.tar.gz.
File metadata
- Download URL: md2bbcode-1.1.0.tar.gz
- Upload date:
- Size: 26.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f01eccf1309a7e41cc814aa6cc2a56a97d7f443168e37f09e597b009b908a4aa
|
|
| MD5 |
09b9604ca18929c59d2b699f508220d9
|
|
| BLAKE2b-256 |
674f71e63c88b4713b78f2f55a06ab45027f888e2245883fdeb57777851d64a9
|
Provenance
The following attestation bundles were made for md2bbcode-1.1.0.tar.gz:
Publisher:
publish.yml on RedGuides/md2bbcode
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
md2bbcode-1.1.0.tar.gz -
Subject digest:
f01eccf1309a7e41cc814aa6cc2a56a97d7f443168e37f09e597b009b908a4aa - Sigstore transparency entry: 950723260
- Sigstore integration time:
-
Permalink:
RedGuides/md2bbcode@1fa2c87e466c5458e25dd18e6b8373a4da3b6b32 -
Branch / Tag:
refs/tags/v1.1.0 - Owner: https://github.com/RedGuides
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1fa2c87e466c5458e25dd18e6b8373a4da3b6b32 -
Trigger Event:
push
-
Statement type:
File details
Details for the file md2bbcode-1.1.0-py2.py3-none-any.whl.
File metadata
- Download URL: md2bbcode-1.1.0-py2.py3-none-any.whl
- Upload date:
- Size: 27.6 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
749a8eb5fdd5252442b711ffbf791fd37d014d2d3c312d02929eeb32c30827c9
|
|
| MD5 |
253260b9a15abcea34a8a79ed8b2b4cf
|
|
| BLAKE2b-256 |
4f6cf9ddd96863024b5fff995e4af1e55a2d409731e629198c933aa26980652f
|
Provenance
The following attestation bundles were made for md2bbcode-1.1.0-py2.py3-none-any.whl:
Publisher:
publish.yml on RedGuides/md2bbcode
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
md2bbcode-1.1.0-py2.py3-none-any.whl -
Subject digest:
749a8eb5fdd5252442b711ffbf791fd37d014d2d3c312d02929eeb32c30827c9 - Sigstore transparency entry: 950723302
- Sigstore integration time:
-
Permalink:
RedGuides/md2bbcode@1fa2c87e466c5458e25dd18e6b8373a4da3b6b32 -
Branch / Tag:
refs/tags/v1.1.0 - Owner: https://github.com/RedGuides
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1fa2c87e466c5458e25dd18e6b8373a4da3b6b32 -
Trigger Event:
push
-
Statement type: