handle empty config structs

pull/3556/head
Alexander Medvednikov 2020-01-24 18:57:32 +01:00
parent 2897bac549
commit f55646746c
3 changed files with 25 additions and 1 deletions

View File

@ -903,7 +903,7 @@ fn (p mut Parser) factor() string {
return p.map_init() return p.map_init()
} }
peek2 := p.tokens[p.token_idx + 1] peek2 := p.tokens[p.token_idx + 1]
if p.peek() == .name && peek2.tok == .colon { if p.peek() == .rcbr || (p.peek() == .name && peek2.tok == .colon) {
if !p.expected_type.ends_with('Config') { if !p.expected_type.ends_with('Config') {
p.error('short struct initialization syntax only works with structs that end with `Config`') p.error('short struct initialization syntax only works with structs that end with `Config`')
} }

View File

@ -493,10 +493,19 @@ fn (p mut Parser) gen_struct_init(typ string, t &Type) bool {
if typ == 'tm' { if typ == 'tm' {
p.cgen.lines[p.cgen.lines.len - 1] = '' p.cgen.lines[p.cgen.lines.len - 1] = ''
} }
mut is_config := false
if p.tok != .lcbr { if p.tok != .lcbr {
p.next() p.next()
} else {
is_config = true
} }
p.check(.lcbr) p.check(.lcbr)
// Handle empty config ({})
if is_config && p.tok == .rcbr {
p.check(.rcbr)
p.gen('($typ) {}')
return true
}
ptr := typ.contains('*') ptr := typ.contains('*')
// `user := User{foo:bar}` => `User user = (User){ .foo = bar}` // `user := User{foo:bar}` => `User user = (User){ .foo = bar}`
if !ptr { if !ptr {

View File

@ -194,3 +194,18 @@ fn test_fixed_field() {
} }
*/ */
struct Config {
n int
def int = 10
}
fn foo_config(c Config) {
}
fn test_config() {
foo_config({n: 10, def: 20})
foo_config({})
}