A CLI tool and Rust library to format and beautify Markdown files with configurable style rules.
- ✨ Table Formatting: Align columns, consistent padding, and clean appearance
- 📝 Heading Normalization: Consistent spacing and hash mark formatting
- 📋 List Formatting: Uniform indentation and bullet markers
- 💻 Code Block Styling: Consistent fence styles and language tags
- ⚙️ Configurable: Customize formatting rules via TOML configuration
- 🚀 Fast: Written in Rust for optimal performance
- 📦 Multiple Modes: In-place editing, stdout output, or file output
cargo install beautiful-mdgit clone https://github.com/mewset/beautiful-md.git
cd beautiful-md
cargo install --path .# Format and output to stdout
beautiful-md README.md
# Format file in-place
beautiful-md --in-place README.md
# Format multiple files
beautiful-md --in-place *.md
# Format with custom config
beautiful-md --config my-config.toml README.md
# Check if files need formatting (useful for CI)
beautiful-md --check README.md
# Generate default configuration file
beautiful-md configuse beautiful_md::{Config, format_markdown};
fn main() -> Result<(), Box<dyn std::error::Error>> {
let markdown = "# Heading\n\n|Name|Age|\n|---|---|\n|Alice|30|";
let config = Config::default();
let formatted = format_markdown(markdown, &config)?;
println!("{}", formatted);
Ok(())
}Create a .beautiful-md.toml file in your project root or home directory:
[tables]
align = true
min_column_width = 3
padding = 1
[headings]
blank_lines_before = 1
blank_lines_after = 1
space_after_hash = true
[lists]
indent_size = 2
marker = "-"
normalize_numbers = true
[code]
ensure_language_tag = false
fence_style = "```"align(bool): Enable column alignmentmin_column_width(usize): Minimum width for columnspadding(usize): Spaces around cell content
blank_lines_before(usize): Empty lines before headingsblank_lines_after(usize): Empty lines after headingsspace_after_hash(bool): Ensure space after#symbols
indent_size(usize): Spaces per indentation levelmarker(string): Bullet character (-,*, or+)normalize_numbers(bool): Fix ordered list numbering
ensure_language_tag(bool): Require language tagsfence_style(string): Fence style (```or~~~)
#Heading Without Space
|Name|Age|City|
|---|---|---|
|Alice|30|Stockholm|
|Bob|25|Göteborg|
- Item 1
* Item 2
+ Item 3# Heading With Space
| Name | Age | City |
| ----- | --- | --------- |
| Alice | 30 | Stockholm |
| Bob | 25 | Göteborg |
- Item 1
- Item 2
- Item 3- Rust 1.70 or later
- Cargo
cargo build --releasecargo testcargo clippy -- -D warnings
cargo fmt --checkContributions are welcome! Please see CONTRIBUTING.md for details.
Licensed under either of:
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.