[][src]Crate join_lazy_fmt

join-lazy-fmt

Lazy separator.join(iterable) method and lazy_format! for Rust

Repository Latest version Documentation License

Usage

  1. Add the following line to your Cargo.toml, under [dependencies]

    join-lazy-fmt = "0.9.2"
    
  2. Add the folowing line to your .rs code to bring items in scope:

    use ::join_lazy_fmt::*;

Example

This code runs with edition 2018
use ::join_lazy_fmt::*;

let sequence = format!("[{}]", ", ".join(0 .. 5));
assert_eq!(sequence, "[0, 1, 2, 3, 4]");

// Since `.join()` is lazy, this does not compute an infinite string.
let _ = ", ".join(0 ..);

const N: usize = 6;
let line = format!("+-{}-+", "-+-".join((1 .. N).map(|_| "---")));
// And the following allocates only one `String`:
let matrix = format!(
    "{line}\n{body}\n{line}\n",
    line=line,
    body="\n".join(
        (1 .. N).map(|i| lazy_format!(
            "| {row} |",
            row=" | ".join(
                (1 .. N).map(|j| lazy_format!(
                    "a{i}{j}",
                    i=i,
                    j=j,
                ))
            ),
        ))
    ),
);
assert_eq!(matrix, "\
+-----+-----+-----+-----+-----+
| a11 | a12 | a13 | a14 | a15 |
| a21 | a22 | a23 | a24 | a25 |
| a31 | a32 | a33 | a34 | a35 |
| a41 | a42 | a43 | a44 | a45 |
| a51 | a52 | a53 | a54 | a55 |
+-----+-----+-----+-----+-----+
");

Macros

lazy_format

Lazy formatting, see LazyFormat.

Structs

DisplayableJoin

The return value of Join::join, which is lazily Displayable.

LazyFormat

Value returned by lazy_format!: struct implementing fmt::Display, thanks to the inner closure expliciting the formatting logic.

Traits

Join

separator.join(iterable) method on anything Displayable.