1 unstable release
new 0.1.0 | Jan 20, 2025 |
---|
#2242 in Parser implementations
12KB
129 lines
JSON to Markdown Renderer in Rust
Overview
A powerful and flexible Rust library for converting complex JSON structures into beautifully formatted Markdown documents. This library provides a highly customizable renderer that can transform nested JSON objects into clean, hierarchical markdown.
Features
- 🚀 Supports deeply nested JSON structures
- 📝 Configurable indentation and rendering styles
- 🔍 Handles various JSON value types (objects, arrays, strings, numbers, booleans)
- 🧩 Modular design with easy extensibility
Installation
Add the following to your Cargo.toml
:
[dependencies]
json2markdown = "0.1.0"
serde_json = "1"
Basic Usage
use serde_json::Value;
use json2markdown::MarkdownRenderer;
fn main() {
let json: Value = serde_json::from_str(r#"{"title": "My Project"}"#).unwrap();
let renderer = MarkdownRenderer::new(1, 2);
let markdown = renderer.render(&json);
println!("{}", markdown);
}
Customization
Indentation
You can customize indentation by adjusting the parameters:
// 1 space base indentation, 2 spaces for nested items
let renderer = MarkdownRenderer::new(1, 2);
Advanced Example
let complex_json = serde_json::json!({
"project": {
"name": "Advanced Project",
"goals": [
"Improve efficiency",
"Reduce manual work"
],
"team": {
"size": 5,
"roles": ["Developer", "Designer"]
}
}
});
let renderer = MarkdownRenderer::new(1, 2);
let markdown = renderer.render(&complex_json);
Performance Considerations
- The renderer is designed to handle large, complex JSON structures
- Memory usage scales with JSON complexity
- Recommended for medium to large JSON documents
Contributing
- Fork the repository
- Create your feature branch
- Commit your changes
- Push to the branch
- Create a new Pull Request
License
MIT
Roadmap
- Add support for custom markdown formatting
- Implement more rendering options
- Create configuration presets
- Improve performance for very large JSON structures
- Improve the indentations to suit the style
Dependencies
~0.7–1.6MB
~34K SLoC