mirror of
https://git.proxmox.com/git/rustc
synced 2025-08-23 07:39:42 +00:00
40 lines
1.5 KiB
Rust
40 lines
1.5 KiB
Rust
//! 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.push_record(["#", "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}");
|
|
}
|