pub struct RcDoc<'a, A = ()>(/* private fields */);
Implementations§
Source§impl<'a, A> RcDoc<'a, A>
impl<'a, A> RcDoc<'a, A>
Sourcepub fn as_string<U: Display>(data: U) -> Self
pub fn as_string<U: Display>(data: U) -> Self
The text t.to_string()
.
The given text must not contain line breaks.
Sourcepub fn text<U: Into<Cow<'a, str>>>(data: U) -> Self
pub fn text<U: Into<Cow<'a, str>>>(data: U) -> Self
The given text, which must not contain line breaks.
Sourcepub fn append<D>(self, that: D) -> Selfwhere
D: Pretty<'a, RcAllocator, A>,
pub fn append<D>(self, that: D) -> Selfwhere
D: Pretty<'a, RcAllocator, A>,
Append the given document after this document.
Sourcepub fn intersperse<I, S>(docs: I, separator: S) -> Selfwhere
I: IntoIterator,
I::Item: Pretty<'a, RcAllocator, A>,
S: Pretty<'a, RcAllocator, A> + Clone,
A: Clone,
pub fn intersperse<I, S>(docs: I, separator: S) -> Selfwhere
I: IntoIterator,
I::Item: Pretty<'a, RcAllocator, A>,
S: Pretty<'a, RcAllocator, A> + Clone,
A: Clone,
A single document interspersing the given separator S
between the given documents. For
example, if the documents are [A, B, C, ..., Z]
, this yields [A, S, B, S, C, S, ..., S, Z]
.
Compare the intersperse
method from the itertools
crate.
NOTE: The separator type, S
may need to be cloned. Consider using cheaply cloneable ptr
like RefDoc
or RcDoc
Sourcepub fn flat_alt<D>(self, doc: D) -> Selfwhere
D: Pretty<'a, RcAllocator, A>,
pub fn flat_alt<D>(self, doc: D) -> Selfwhere
D: Pretty<'a, RcAllocator, A>,
Acts as self
when laid out on multiple lines and acts as that
when laid out on a single line.
Sourcepub fn group(self) -> Self
pub fn group(self) -> Self
Mark this document as a group.
Groups are layed out on a single line if possible. Within a group, all basic documents with several possible layouts are assigned the same layout, that is, they are all layed out horizontally and combined into a one single line, or they are each layed out on their own line.
pub fn annotate(self, ann: A) -> Self
pub fn union<D>(self, other: D) -> Self
pub fn softline() -> Self
Sourcepub fn softline_() -> Self
pub fn softline_() -> Self
A softline_
acts like nil
if the document fits the page, otherwise like line_
pub fn column(f: impl Fn(usize) -> Self + 'static) -> Self
pub fn nesting(f: impl Fn(usize) -> Self + 'static) -> Self
Methods from Deref<Target = Doc<'a, RcDoc<'a, A>, A>>§
Sourcepub fn render<W>(&self, width: usize, out: &mut W) -> Result<()>
pub fn render<W>(&self, width: usize, out: &mut W) -> Result<()>
Writes a rendered document to a std::io::Write
object.
Sourcepub fn render_fmt<W>(&self, width: usize, out: &mut W) -> Result
pub fn render_fmt<W>(&self, width: usize, out: &mut W) -> Result
Writes a rendered document to a std::fmt::Write
object.
Sourcepub fn render_raw<W>(&self, width: usize, out: &mut W) -> Result<(), W::Error>where
for<'b> W: RenderAnnotated<'b, A> + ?Sized,
pub fn render_raw<W>(&self, width: usize, out: &mut W) -> Result<(), W::Error>where
for<'b> W: RenderAnnotated<'b, A> + ?Sized,
Writes a rendered document to a RenderAnnotated<A>
object.
Sourcepub fn pretty<'d>(&'d self, width: usize) -> PrettyFmt<'a, 'd, T, A>
pub fn pretty<'d>(&'d self, width: usize) -> PrettyFmt<'a, 'd, T, A>
Returns a value which implements std::fmt::Display
use pretty::{Doc, BoxDoc};
let doc = BoxDoc::<()>::group(
BoxDoc::text("hello").append(Doc::line()).append(Doc::text("world"))
);
assert_eq!(format!("{}", doc.pretty(80)), "hello world");
Trait Implementations§
Source§impl<'a, A> Pretty<'a, RcAllocator, A> for RcDoc<'a, A>where
A: 'a,
impl<'a, A> Pretty<'a, RcAllocator, A> for RcDoc<'a, A>where
A: 'a,
Source§fn pretty(self, allocator: &'a RcAllocator) -> DocBuilder<'a, RcAllocator, A>
fn pretty(self, allocator: &'a RcAllocator) -> DocBuilder<'a, RcAllocator, A>
self
into a document