Merge pull request #3200 from scampi/issue-3194

compute the span after a struct-like item based on the ident description
This commit is contained in:
Nick Cameron 2018-11-14 17:08:05 +13:00 committed by GitHub
commit ef75b726c4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 71 additions and 3 deletions

View File

@ -464,7 +464,8 @@ impl<'a> FmtVisitor<'a> {
BracePos::Auto
},
self.block_indent,
mk_sp(span.lo(), body_start),
// make a span that starts right after `enum Foo`
mk_sp(ident.span.hi(), body_start),
last_line_width(&enum_header),
)
.unwrap();
@ -1186,7 +1187,8 @@ fn format_unit_struct(context: &RewriteContext, p: &StructParts, offset: Indent)
context.config.brace_style(),
BracePos::None,
offset,
mk_sp(generics.span.lo(), hi),
// make a span that starts right after `struct Foo`
mk_sp(p.ident.span.hi(), hi),
last_line_width(&header_str),
)?
} else {
@ -1208,7 +1210,7 @@ pub fn format_struct_struct(
let header_str = struct_parts.format_header(context);
result.push_str(&header_str);
let header_hi = span.lo() + BytePos(header_str.len() as u32);
let header_hi = struct_parts.ident.span.hi();
let body_lo = context.snippet_provider.span_after(span, "{");
let generics_str = match struct_parts.generics {
@ -1222,6 +1224,7 @@ pub fn format_struct_struct(
BracePos::Auto
},
offset,
// make a span that starts right after `struct Foo`
mk_sp(header_hi, body_lo),
last_line_width(&result),
)?,

View File

@ -0,0 +1,13 @@
mod m { struct S where A: B; }
mod n { struct Foo where A: B { foo: usize } }
mod o { enum Bar where A: B { Bar } }
mod with_comments {
mod m { struct S /* before where */ where A: B; /* after where */ }
mod n { struct Foo /* before where */ where A: B /* after where */ { foo: usize } }
mod o { enum Bar /* before where */ where A: B /* after where */ { Bar } }
}

View File

@ -0,0 +1,52 @@
mod m {
struct S
where
A: B;
}
mod n {
struct Foo
where
A: B,
{
foo: usize,
}
}
mod o {
enum Bar
where
A: B,
{
Bar,
}
}
mod with_comments {
mod m {
struct S
/* before where */
where
A: B; /* after where */
}
mod n {
struct Foo
/* before where */
where
A: B, /* after where */
{
foo: usize,
}
}
mod o {
enum Bar
/* before where */
where
A: B, /* after where */
{
Bar,
}
}
}