v2: more parser fixes

pull/3729/head
Alexander Medvednikov 2020-02-13 01:06:34 +01:00
parent f00ab076d1
commit 8dd905a14d
3 changed files with 61 additions and 30 deletions

View File

@ -470,12 +470,12 @@ pub fn (p mut Parser) parse_ident(is_c bool) (ast.Ident,table.Type) {
fn (p mut Parser) struct_init() (ast.Expr,table.Type) { fn (p mut Parser) struct_init() (ast.Expr,table.Type) {
mut node := ast.Expr{} mut node := ast.Expr{}
typ := p.parse_type() typ := p.parse_type()
// p.warn('struct init typ=$typ.name') sym := p.table.get_type_symbol(typ)
// p.warn('struct init typ=$sym.name')
p.check(.lcbr) p.check(.lcbr)
mut field_names := []string mut field_names := []string
mut exprs := []ast.Expr mut exprs := []ast.Expr
mut i := 0 mut i := 0
sym := p.table.get_type_symbol(typ)
// TODO if sym.info is table.Struct // TODO if sym.info is table.Struct
mut is_struct := false mut is_struct := false
match sym.info { match sym.info {
@ -492,7 +492,7 @@ fn (p mut Parser) struct_init() (ast.Expr,table.Type) {
if is_struct { if is_struct {
info := sym.info as table.Struct info := sym.info as table.Struct
field := sym.find_field(field_name) or { field := sym.find_field(field_name) or {
p.error(err) p.error('field `${sym.name}.$field_name` not found')
continue continue
} }
p.expected_type = field.typ p.expected_type = field.typ
@ -527,10 +527,12 @@ pub fn (p mut Parser) name_expr() (ast.Expr,table.Type) {
p.next() p.next()
p.check(.dot) p.check(.dot)
} }
// `map[string]int` initialization
if p.tok.lit == 'map' && p.peek_tok.kind == .lsbr { if p.tok.lit == 'map' && p.peek_tok.kind == .lsbr {
map_type := p.parse_map_type(0) map_type := p.parse_map_type(0)
return node,typ return node,typ
} }
// p.warn('name expr $p.tok.lit')
// fn call or type cast // fn call or type cast
if p.peek_tok.kind == .lpar { if p.peek_tok.kind == .lpar {
name := p.tok.lit name := p.tok.lit
@ -562,8 +564,8 @@ pub fn (p mut Parser) name_expr() (ast.Expr,table.Type) {
typ = ti2 typ = ti2
} }
} }
// struct init
else if p.peek_tok.kind == .lcbr && (p.tok.lit[0].is_capital() || is_c || p.tok.lit in ['array', 'string', 'ustring', 'mapnode', 'map']) && !p.tok.lit[p.tok.lit.len - 1].is_capital() { else if p.peek_tok.kind == .lcbr && (p.tok.lit[0].is_capital() || is_c || p.tok.lit in ['array', 'string', 'ustring', 'mapnode', 'map']) && !p.tok.lit[p.tok.lit.len - 1].is_capital() {
p.warn('!! s init $p.tok.lit')
// || p.table.known_type(p.tok.lit)) { // || p.table.known_type(p.tok.lit)) {
return p.struct_init() return p.struct_init()
} }
@ -1167,7 +1169,7 @@ fn (p mut Parser) parse_import() ast.Import {
p.check(.key_as) p.check(.key_as)
mod_alias = p.check_name() mod_alias = p.check_name()
} }
p.table.imports << mod_name p.table.imports << mod_name.all_after('.')
return ast.Import{ return ast.Import{
mod: mod_name mod: mod_name
alias: mod_alias alias: mod_alias
@ -1432,14 +1434,23 @@ fn (p mut Parser) match_expr() (ast.Expr,table.Type) {
p.next() p.next()
} }
cond,typ := p.expr(0) cond,typ := p.expr(0)
// sym := p.table.get_type_symbol(typ)
// p.warn('match typ $sym.name')
p.check(.lcbr) p.check(.lcbr)
mut blocks := []ast.StmtBlock mut blocks := []ast.StmtBlock
mut match_exprs := []ast.Expr mut match_exprs := []ast.Expr
mut return_type := table.void_type mut return_type := table.void_type
for { for {
// Sum type match // Sum type match
if p.tok.kind == .name && p.tok.lit[0].is_capital() { if p.tok.kind == .name && (p.tok.lit[0].is_capital() || p.peek_tok.kind == .dot) {
// if sym.kind == .sum_type {
// p.warn('is sum')
// p.parse_type()
p.check_name() p.check_name()
if p.tok.kind == .dot {
p.check(.dot)
p.check_name()
}
} }
else { else {
// Expression match // Expression match
@ -1522,6 +1533,7 @@ fn (p mut Parser) type_decl() ast.TypeDecl {
} }
p.check(.key_type) p.check(.key_type)
name := p.check_name() name := p.check_name()
mut is_sum := false
// type SumType = A | B | c // type SumType = A | B | c
if p.tok.kind == .assign { if p.tok.kind == .assign {
p.next() p.next()
@ -1531,11 +1543,20 @@ fn (p mut Parser) type_decl() ast.TypeDecl {
break break
} }
p.check(.pipe) p.check(.pipe)
is_sum = true
} }
} }
else { else {
p.check_name() p.check_name()
} }
p.table.register_type_symbol(table.TypeSymbol{
parent: 0
kind: .sum_type
name: name
info: table.Alias{
foo: ''
}
})
return ast.TypeDecl{ return ast.TypeDecl{
name: name name: name
} }

View File

@ -118,7 +118,9 @@ fn filter_num_sep(txt byteptr, start int, end int) string {
} }
b[i1] = 0 // C string compatibility b[i1] = 0 // C string compatibility
return string{ return string{
b,i1} str: b
len: i1
}
} }
} }

View File

@ -3,7 +3,8 @@
// that can be found in the LICENSE file. // that can be found in the LICENSE file.
module table module table
pub type TypeInfo = Array | ArrayFixed | Map | Struct | MultiReturn pub type TypeInfo = Array | ArrayFixed | Map | Struct |
MultiReturn | Alias
pub struct TypeSymbol { pub struct TypeSymbol {
pub: pub:
@ -13,10 +14,11 @@ mut:
kind Kind kind Kind
name string name string
methods []Fn methods []Fn
// is_sum bool
} }
pub const ( pub const (
// primitive types // primitive types
void_type_idx = 1 void_type_idx = 1
voidptr_type_idx = 2 voidptr_type_idx = 2
byteptr_type_idx = 3 byteptr_type_idx = 3
@ -40,12 +42,17 @@ pub const (
) )
pub const ( pub const (
builtin_type_names = [ builtin_type_names = ['void', 'voidptr', 'charptr', 'byteptr', 'i8', 'i16', 'int', 'i64', 'u16', 'u32', 'u64',
'void', 'voidptr', 'charptr', 'byteptr', 'i8', 'i16', 'int', 'i64', 'u16', 'u32', 'u64', 'f32', 'f64', 'string', 'char', 'byte', 'bool', 'struct', 'array', 'array_fixed', 'map']
'f32' ,'f64', 'string', 'char', 'byte' ,'bool', 'struct', 'array', 'array_fixed', 'map'
]
) )
pub struct MultiReturn {
pub:
name string
mut:
types []Type
}
pub enum Kind { pub enum Kind {
placeholder placeholder
void void
@ -70,11 +77,13 @@ pub enum Kind {
array_fixed array_fixed
map map
multi_return multi_return
sum_type
alias
unresolved unresolved
} }
[inline] [inline]
pub fn(t &TypeSymbol) mr_info() MultiReturn { pub fn (t &TypeSymbol) mr_info() MultiReturn {
match t.info { match t.info {
MultiReturn { MultiReturn {
return it return it
@ -86,7 +95,7 @@ pub fn(t &TypeSymbol) mr_info() MultiReturn {
} }
[inline] [inline]
pub fn(t &TypeSymbol) array_info() Array { pub fn (t &TypeSymbol) array_info() Array {
match t.info { match t.info {
Array { Array {
return it return it
@ -98,7 +107,7 @@ pub fn(t &TypeSymbol) array_info() Array {
} }
[inline] [inline]
pub fn(t &TypeSymbol) array_fixed_info() ArrayFixed { pub fn (t &TypeSymbol) array_fixed_info() ArrayFixed {
match t.info { match t.info {
ArrayFixed { ArrayFixed {
return it return it
@ -110,7 +119,7 @@ pub fn(t &TypeSymbol) array_fixed_info() ArrayFixed {
} }
[inline] [inline]
pub fn(t &TypeSymbol) map_info() Map { pub fn (t &TypeSymbol) map_info() Map {
match t.info { match t.info {
Map { Map {
return it return it
@ -127,6 +136,7 @@ pub fn (t TypeSymbol) str() string {
} }
*/ */
[inline] [inline]
pub fn array_name(elem_type &TypeSymbol, nr_dims int) string { pub fn array_name(elem_type &TypeSymbol, nr_dims int) string {
return 'array_${elem_type.name}' + if nr_dims > 1 { '_${nr_dims}d' } else { '' } return 'array_${elem_type.name}' + if nr_dims > 1 { '_${nr_dims}d' } else { '' }
@ -364,6 +374,11 @@ pub mut:
fields []Field fields []Field
} }
pub struct Alias {
pub:
foo string
}
pub struct Field { pub struct Field {
pub: pub:
name string name string
@ -391,10 +406,3 @@ pub mut:
key_type Type key_type Type
value_type Type value_type Type
} }
pub struct MultiReturn {
pub:
name string
mut:
types []Type
}