vfmt: fix comments before ...f in Abc{...f} (#7870)

pull/7871/head
Daniel Däschle 2021-01-04 20:01:35 +01:00 committed by GitHub
parent bf904c2f82
commit 7c9fb73b3f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 37 additions and 14 deletions

View File

@ -247,16 +247,17 @@ pub mut:
pub struct StructInit {
pub:
pos token.Position
is_short bool
pos token.Position
is_short bool
pub mut:
pre_comments []Comment
typ table.Type
update_expr Expr
update_expr_type table.Type
has_update_expr bool
fields []StructInitField
embeds []StructInitEmbed
pre_comments []Comment
typ table.Type
update_expr Expr
update_expr_type table.Type
update_expr_comments []Comment
has_update_expr bool
fields []StructInitField
embeds []StructInitEmbed
}
// import statement

View File

@ -2054,13 +2054,14 @@ pub fn (mut f Fmt) struct_init(it ast.StructInit) {
}
init_start := f.out.len
f.indent++
if it.has_update_expr {
f.write('...')
f.expr(it.update_expr)
f.writeln('')
}
short_args_loop: for {
f.comments(it.pre_comments, inline: true, has_nl: true, level: .keep)
if it.has_update_expr {
f.write('...')
f.expr(it.update_expr)
f.writeln('')
f.comments(it.update_expr_comments, inline: true, has_nl: true, level: .keep)
}
for i, field in it.fields {
f.write('$field.name: ')
f.prefix_expr_cast_expr(field.expr)

View File

@ -0,0 +1,18 @@
struct Foo {
name string
age int
}
struct Foo2 {}
fn main() {
f := Foo{
name: 'test'
age: 18
}
f2 := Foo{
// before
...f // after
name: 'f2'
}
}

View File

@ -336,6 +336,7 @@ fn (mut p Parser) struct_init(short_syntax bool) ast.StructInit {
saved_is_amp := p.is_amp
p.is_amp = false
mut update_expr := ast.Expr{}
mut update_expr_comments := []ast.Comment{}
mut has_update_expr := false
for p.tok.kind !in [.rcbr, .rpar, .eof] {
mut field_name := ''
@ -353,6 +354,7 @@ fn (mut p Parser) struct_init(short_syntax bool) ast.StructInit {
// struct updating syntax; f2 := Foo{ ...f, name: 'f2' }
p.check(.ellipsis)
update_expr = p.expr(0)
update_expr_comments << p.eat_line_end_comments()
has_update_expr = true
} else {
first_field_pos := p.tok.position()
@ -394,6 +396,7 @@ fn (mut p Parser) struct_init(short_syntax bool) ast.StructInit {
typ: typ
fields: fields
update_expr: update_expr
update_expr_comments: update_expr_comments
has_update_expr: has_update_expr
pos: token.Position{
line_nr: first_pos.line_nr