Trait pretty::DocAllocator
source · pub trait DocAllocator<'a, A = ()> {
type Doc: Deref<Target = Doc<'a, Self::Doc, A>>;
// Required method
fn alloc(&'a self, _: Doc<'a, Self::Doc, A>) -> Self::Doc;
// Provided methods
fn nil(&'a self) -> DocBuilder<'a, Self, A> { ... }
fn newline(&'a self) -> DocBuilder<'a, Self, A> { ... }
fn space(&'a self) -> DocBuilder<'a, Self, A> { ... }
fn as_string<U: ToString>(&'a self, data: U) -> DocBuilder<'a, Self, A> { ... }
fn text<U: Into<Cow<'a, str>>>(&'a self, data: U) -> DocBuilder<'a, Self, A> { ... }
fn concat<I>(&'a self, docs: I) -> DocBuilder<'a, Self, A>
where I: IntoIterator,
I::Item: Into<Doc<'a, Self::Doc, A>> { ... }
fn intersperse<I, S>(
&'a self,
docs: I,
separator: S
) -> DocBuilder<'a, Self, A>
where I: IntoIterator,
I::Item: Into<Doc<'a, Self::Doc, A>>,
S: Into<Doc<'a, Self::Doc, A>> + Clone { ... }
}
Expand description
The DocAllocator
trait abstracts over a type which can allocate (pointers to) Doc
.
Required Associated Types§
Required Methods§
Provided Methods§
sourcefn nil(&'a self) -> DocBuilder<'a, Self, A>
fn nil(&'a self) -> DocBuilder<'a, Self, A>
Allocate an empty document.
sourcefn newline(&'a self) -> DocBuilder<'a, Self, A>
fn newline(&'a self) -> DocBuilder<'a, Self, A>
Allocate a single newline.
sourcefn space(&'a self) -> DocBuilder<'a, Self, A>
fn space(&'a self) -> DocBuilder<'a, Self, A>
Allocate a single space.
sourcefn as_string<U: ToString>(&'a self, data: U) -> DocBuilder<'a, Self, A>
fn as_string<U: ToString>(&'a self, data: U) -> DocBuilder<'a, Self, A>
Allocate a document containing the text t.to_string()
.
The given text must not contain line breaks.
sourcefn text<U: Into<Cow<'a, str>>>(&'a self, data: U) -> DocBuilder<'a, Self, A>
fn text<U: Into<Cow<'a, str>>>(&'a self, data: U) -> DocBuilder<'a, Self, A>
Allocate a document containing the given text.
The given text must not contain line breaks.
sourcefn concat<I>(&'a self, docs: I) -> DocBuilder<'a, Self, A>
fn concat<I>(&'a self, docs: I) -> DocBuilder<'a, Self, A>
Allocate a document concatenating the given documents.
sourcefn intersperse<I, S>(&'a self, docs: I, separator: S) -> DocBuilder<'a, Self, A>
fn intersperse<I, S>(&'a self, docs: I, separator: S) -> DocBuilder<'a, Self, A>
Allocate a document that intersperses the given separator S
between the given documents
[A, B, C, ..., Z]
, yielding [A, S, B, S, C, S, ..., S, Z]
.
Object Safety§
This trait is not object safe.