Work around removal of beginning_vert field from ast::Arm
`ast::Arm` used to have `beginning_vert` field whose type is `Option<Span>` and holds a span of the beginning `|` if available. This field is now removed. This commit works around that. Since we only need a `BytePos` of the `|`, the type of `beginning_vert` in `ArmWrapper` is `Option<BytePos>`.
This commit is contained in:
parent
5416c4df76
commit
d7495324bc
60
src/expr.rs
60
src/expr.rs
@ -1231,23 +1231,43 @@ pub fn is_unsafe_block(block: &ast::Block) -> bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// A simple wrapper type against ast::Arm. Used inside write_list().
|
/// A simple wrapper type against ast::Arm. Used inside write_list().
|
||||||
struct ArmWrapper<'a> {
|
struct ArmWrapper<'a> {
|
||||||
pub arm: &'a ast::Arm,
|
pub arm: &'a ast::Arm,
|
||||||
// True if the arm is the last one in match expression. Used to decide on whether we should add
|
/// True if the arm is the last one in match expression. Used to decide on whether we should add
|
||||||
// trailing comma to the match arm when `config.trailing_comma() == Never`.
|
/// trailing comma to the match arm when `config.trailing_comma() == Never`.
|
||||||
pub is_last: bool,
|
pub is_last: bool,
|
||||||
|
/// Holds a byte position of `|` at the beginning of the arm pattern, if available.
|
||||||
|
pub beginning_vert: Option<BytePos>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> ArmWrapper<'a> {
|
impl<'a> ArmWrapper<'a> {
|
||||||
pub fn new(arm: &'a ast::Arm, is_last: bool) -> ArmWrapper<'a> {
|
pub fn new(
|
||||||
ArmWrapper { arm, is_last }
|
arm: &'a ast::Arm,
|
||||||
|
is_last: bool,
|
||||||
|
beginning_vert: Option<BytePos>,
|
||||||
|
) -> ArmWrapper<'a> {
|
||||||
|
ArmWrapper {
|
||||||
|
arm,
|
||||||
|
is_last,
|
||||||
|
beginning_vert,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> Spanned for ArmWrapper<'a> {
|
||||||
|
fn span(&self) -> Span {
|
||||||
|
if let Some(lo) = self.beginning_vert {
|
||||||
|
mk_sp(lo, self.arm.span().hi())
|
||||||
|
} else {
|
||||||
|
self.arm.span()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Rewrite for ArmWrapper<'a> {
|
impl<'a> Rewrite for ArmWrapper<'a> {
|
||||||
fn rewrite(&self, context: &RewriteContext, shape: Shape) -> Option<String> {
|
fn rewrite(&self, context: &RewriteContext, shape: Shape) -> Option<String> {
|
||||||
rewrite_match_arm(context, self.arm, shape, self.is_last)
|
rewrite_match_arm(context, self.arm, shape, self.is_last, self.beginning_vert)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1344,6 +1364,23 @@ fn arm_comma(config: &Config, body: &ast::Expr, is_last: bool) -> &'static str {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Collect a byte position of the beginning `|` for each arm, if available.
|
||||||
|
fn collect_beginning_verts(
|
||||||
|
context: &RewriteContext,
|
||||||
|
arms: &[ast::Arm],
|
||||||
|
span: Span,
|
||||||
|
) -> Vec<Option<BytePos>> {
|
||||||
|
let mut beginning_verts = Vec::with_capacity(arms.len());
|
||||||
|
let mut lo = context.snippet_provider.span_after(span, "{");
|
||||||
|
for arm in arms {
|
||||||
|
let hi = arm.pats[0].span.lo();
|
||||||
|
let missing_span = mk_sp(lo, hi);
|
||||||
|
beginning_verts.push(context.snippet_provider.opt_span_before(missing_span, "|"));
|
||||||
|
lo = arm.span().hi();
|
||||||
|
}
|
||||||
|
beginning_verts
|
||||||
|
}
|
||||||
|
|
||||||
fn rewrite_match_arms(
|
fn rewrite_match_arms(
|
||||||
context: &RewriteContext,
|
context: &RewriteContext,
|
||||||
arms: &[ast::Arm],
|
arms: &[ast::Arm],
|
||||||
@ -1359,15 +1396,17 @@ fn rewrite_match_arms(
|
|||||||
let is_last_iter = repeat(false)
|
let is_last_iter = repeat(false)
|
||||||
.take(arm_len.checked_sub(1).unwrap_or(0))
|
.take(arm_len.checked_sub(1).unwrap_or(0))
|
||||||
.chain(repeat(true));
|
.chain(repeat(true));
|
||||||
|
let beginning_verts = collect_beginning_verts(context, arms, span);
|
||||||
let items = itemize_list(
|
let items = itemize_list(
|
||||||
context.snippet_provider,
|
context.snippet_provider,
|
||||||
arms.iter()
|
arms.iter()
|
||||||
.zip(is_last_iter)
|
.zip(is_last_iter)
|
||||||
.map(|(arm, is_last)| ArmWrapper::new(arm, is_last)),
|
.zip(beginning_verts.into_iter())
|
||||||
|
.map(|((arm, is_last), beginning_vert)| ArmWrapper::new(arm, is_last, beginning_vert)),
|
||||||
"}",
|
"}",
|
||||||
"|",
|
"|",
|
||||||
|arm| arm.arm.span().lo(),
|
|arm| arm.span().lo(),
|
||||||
|arm| arm.arm.span().hi(),
|
|arm| arm.span().hi(),
|
||||||
|arm| arm.rewrite(context, arm_shape),
|
|arm| arm.rewrite(context, arm_shape),
|
||||||
open_brace_pos,
|
open_brace_pos,
|
||||||
span.hi(),
|
span.hi(),
|
||||||
@ -1394,6 +1433,7 @@ fn rewrite_match_arm(
|
|||||||
arm: &ast::Arm,
|
arm: &ast::Arm,
|
||||||
shape: Shape,
|
shape: Shape,
|
||||||
is_last: bool,
|
is_last: bool,
|
||||||
|
beginning_vert: Option<BytePos>,
|
||||||
) -> Option<String> {
|
) -> Option<String> {
|
||||||
let (missing_span, attrs_str) = if !arm.attrs.is_empty() {
|
let (missing_span, attrs_str) = if !arm.attrs.is_empty() {
|
||||||
if contains_skip(&arm.attrs) {
|
if contains_skip(&arm.attrs) {
|
||||||
@ -1417,7 +1457,7 @@ fn rewrite_match_arm(
|
|||||||
context,
|
context,
|
||||||
&arm.pats,
|
&arm.pats,
|
||||||
&arm.guard,
|
&arm.guard,
|
||||||
arm.beginning_vert.is_some(),
|
beginning_vert.is_some(),
|
||||||
shape,
|
shape,
|
||||||
).and_then(|pats_str| {
|
).and_then(|pats_str| {
|
||||||
combine_strs_with_missing_comments(
|
combine_strs_with_missing_comments(
|
||||||
|
@ -89,10 +89,10 @@ impl Spanned for ast::Ty {
|
|||||||
|
|
||||||
impl Spanned for ast::Arm {
|
impl Spanned for ast::Arm {
|
||||||
fn span(&self) -> Span {
|
fn span(&self) -> Span {
|
||||||
let lo = if let Some(sp) = self.beginning_vert {
|
let lo = if self.attrs.is_empty() {
|
||||||
sp.lo()
|
|
||||||
} else {
|
|
||||||
self.pats[0].span.lo()
|
self.pats[0].span.lo()
|
||||||
|
} else {
|
||||||
|
self.attrs[0].span.lo()
|
||||||
};
|
};
|
||||||
span_with_attrs_lo_hi!(self, lo, self.body.span.hi())
|
span_with_attrs_lo_hi!(self, lo, self.body.span.hi())
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user