summaryrefslogtreecommitdiffstats
path: root/vendor/tabled/examples/builder.rs
blob: 6baf29c2436bb9c68bf3fa64b47cee6ecfe92f2a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
//! This example demonstrates an alternative method for creating a [`Table`].
//! [`Builder`] is an efficient implementation of the [builder design pattern](https://en.wikipedia.org/wiki/Builder_pattern).
//!
//! > The intent of the Builder design pattern is to separate the construction of a complex object from its representation.
//! > -- <cite>Wikipedia</cite>
//!
//! * Note how [Builder] can be used to define a table's shape manually
//!  and can be populated through iteration if it is mutable. This flexibility
//! is useful when you don't have direct control over the datasets you intend to [table](tabled).

use tabled::{
    builder::Builder,
    settings::{object::Rows, Modify, Panel, Style, Width},
};

fn main() {
    let message = r#"The terms "the ocean" or "the sea" used without specification refer to the interconnected body of salt water covering the majority of the Earth's surface"#;
    let link = r#"https://en.wikipedia.org/wiki/Ocean"#;

    let oceans = ["Atlantic", "Pacific", "Indian", "Southern", "Arctic"];

    let mut builder = Builder::default();
    builder.set_header(["#", "Ocean"]);
    for (i, ocean) in oceans.iter().enumerate() {
        builder.push_record([i.to_string(), ocean.to_string()]);
    }

    let table = builder
        .build()
        .with(Panel::header(message))
        .with(Panel::header(link))
        .with(Panel::horizontal(2, "=".repeat(link.len())))
        .with(Modify::new(Rows::single(1)).with(Width::wrap(link.len())))
        .with(Style::markdown())
        .to_string();

    println!("{table}");
}