v2: more parser fixes
parent
f00ab076d1
commit
8dd905a14d
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue