6 releases (stable)

1.2.1 Sep 21, 2020
1.1.1 Sep 21, 2020
1.0.1 Sep 17, 2020
0.1.1 Sep 16, 2020
0.1.0 Sep 16, 2020

#852 in Encoding

Download history 7389/week @ 2024-06-17 9216/week @ 2024-06-24 5531/week @ 2024-07-01 6680/week @ 2024-07-08 6954/week @ 2024-07-15 5774/week @ 2024-07-22 5484/week @ 2024-07-29 3858/week @ 2024-08-05 4967/week @ 2024-08-12 3708/week @ 2024-08-19 1866/week @ 2024-08-26 1257/week @ 2024-09-02 690/week @ 2024-09-09 861/week @ 2024-09-16 511/week @ 2024-09-23 261/week @ 2024-09-30

2,386 downloads per month
Used in journal_entry

MIT license

34KB
960 lines

markdown-gen

Rust crate for generating Markdown files

Usage

let file = File::create("test.md").unwrap();
let mut md = Markdown::new(file);

md.write("Heading".heading(1)).unwrap();
md.write("Subheading".italic().heading(2)).unwrap();

md.write("bold".bold()).unwrap();

md.write("first paragraph").unwrap();
md.write(
    "Links: ".paragraph()
    .append("Rust".bold().link_to("https://rust-lang.org"))
    .append(", ")
    .append("Google".italic().link_to("https://google.com"))
).unwrap();

md.write(
    List::new(true)
        .title("numbered list")
        .item("item 1")
        .item("bold".bold())
        .item(
                List::new(false)
                    .title("nested bullet list")
                    .item(
                        "bold".bold()
                            .paragraph().append(
                            "italic".italic()
                        )
                    )
           )
).unwrap();

md.write("quote".quote()).unwrap();

This produces the following Markdown document

# Heading
## *Subheading*
**bold**

first paragraph

Links: [**Rust**](https://rust\-lang\.org), [*Google*](https://google\.com)

numbered list
   1. item 1
   1. **bold**
   1. nested bullet list
      * **bold***italic*
>quote

You can also generate Markdown to Vec<u8>:

let mut md = Markdown::new(Vec::new());

md.write("test".heading(1)).unwrap();

let vec = md.into_inner();
assert_eq!(String::from_utf8(vec).unwrap(), "# test\n");

No runtime deps