use pretty::{Doc, RcDoc};
use crate::TAB;
pub(crate) fn intersperse_line_nest<'a, I>(v: I) -> RcDoc<'a>
where
I: IntoIterator<Item = RcDoc<'a, ()>>,
{
RcDoc::intersperse(v, Doc::line()).nest(TAB).group()
}
pub(crate) fn nest<'a>(title: RcDoc<'a>, v: RcDoc<'a>) -> RcDoc<'a> {
intersperse_line_nest([title, v])
}
pub(crate) fn nest_title<S>(title: S, v: RcDoc) -> RcDoc
where
S: Into<String>,
{
nest(RcDoc::text(title.into()), v)
}
pub(crate) fn title_comma_separate<'a, F, T, S>(title: S, f: F, v: &'a [T]) -> RcDoc<'a, ()>
where
F: Fn(&'a T) -> RcDoc<'a>,
S: Into<String>,
{
let title = RcDoc::text(title.into());
if v.is_empty() {
title
} else {
nest_comma_separate(title, f, v)
}
}
pub(crate) fn nest_comma_separate<'a, F, T: 'a, I>(
title: RcDoc<'a, ()>,
f: F,
v: I,
) -> RcDoc<'a, ()>
where
F: Fn(&'a T) -> RcDoc<'a>,
I: IntoIterator<Item = &'a T>,
{
nest(title, comma_separate(f, v))
}
pub(crate) fn comma_separate<'a, F, T: 'a, I>(f: F, v: I) -> RcDoc<'a, ()>
where
F: Fn(&'a T) -> RcDoc<'a>,
I: IntoIterator<Item = &'a T>,
{
let docs = v.into_iter().map(f);
comma_separated(docs)
}
pub(crate) fn comma_separated<'a, I>(v: I) -> RcDoc<'a, ()>
where
I: IntoIterator<Item = RcDoc<'a, ()>>,
{
RcDoc::intersperse(v, RcDoc::concat([RcDoc::text(","), RcDoc::line()])).group()
}
pub(crate) fn bracket<A: Into<String>, B: Into<String>>(left: A, d: RcDoc, right: B) -> RcDoc {
bracket_doc(
RcDoc::text(left.into()),
d,
RcDoc::text(right.into()),
RcDoc::line_(),
)
}
pub(crate) fn bracket_doc<'a>(
left: RcDoc<'a>,
d: RcDoc<'a>,
right: RcDoc<'a>,
line: RcDoc<'a>,
) -> RcDoc<'a> {
RcDoc::concat([
left,
RcDoc::concat([line.clone(), d]).nest(TAB),
line,
right,
])
.group()
}