method calls; skip string interpolation for now; fix ()
parent
48ea1153a5
commit
69f3c42b99
|
@ -129,7 +129,7 @@ jobs:
|
||||||
../vprod -x64 -o 1m 1m.v
|
../vprod -x64 -o 1m 1m.v
|
||||||
echo "Running it..."
|
echo "Running it..."
|
||||||
ls
|
ls
|
||||||
./1m
|
# ./1m
|
||||||
#run: echo "TODO" #cd examples/x64 && ../../v -x64 hello_world.v && ./hello_world
|
#run: echo "TODO" #cd examples/x64 && ../../v -x64 hello_world.v && ./hello_world
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
pub type Expr = BinaryExpr | UnaryExpr | IfExpr | StringLiteral | IntegerLiteral |
|
pub type Expr = BinaryExpr | UnaryExpr | IfExpr | StringLiteral | IntegerLiteral |
|
||||||
FloatLiteral | Ident | CallExpr | BoolLiteral | StructInit | ArrayInit | SelectorExpr | PostfixExpr | AssignExpr | PrefixExpr
|
FloatLiteral | Ident | CallExpr | BoolLiteral | StructInit | ArrayInit | SelectorExpr | PostfixExpr | AssignExpr | PrefixExpr | MethodCallExpr
|
||||||
|
|
||||||
pub type Stmt = VarDecl | FnDecl | Return | Module | Import | ExprStmt |
|
pub type Stmt = VarDecl | FnDecl | Return | Module | Import | ExprStmt |
|
||||||
ForStmt | StructDecl | ForCStmt | ForInStmt
|
ForStmt | StructDecl | ForCStmt | ForInStmt
|
||||||
|
@ -103,6 +103,16 @@ pub:
|
||||||
|
|
||||||
pub struct CallExpr {
|
pub struct CallExpr {
|
||||||
pub:
|
pub:
|
||||||
|
// func Expr
|
||||||
|
name string
|
||||||
|
args []Expr
|
||||||
|
is_unknown bool
|
||||||
|
tok token.Token
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct MethodCallExpr {
|
||||||
|
pub:
|
||||||
|
expr Expr
|
||||||
name string
|
name string
|
||||||
args []Expr
|
args []Expr
|
||||||
is_unknown bool
|
is_unknown bool
|
||||||
|
|
|
@ -59,6 +59,19 @@ pub fn (p mut Parser) call_expr() (ast.CallExpr,types.TypeIdent) {
|
||||||
return node,return_ti
|
return node,return_ti
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn (p mut Parser) call_args() []ast.Expr {
|
||||||
|
mut args := []ast.Expr
|
||||||
|
for p.tok.kind != .rpar {
|
||||||
|
e,_ := p.expr(0)
|
||||||
|
args << e
|
||||||
|
if p.tok.kind != .rpar {
|
||||||
|
p.check(.comma)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p.check(.rpar)
|
||||||
|
return args // ,types.void_ti
|
||||||
|
}
|
||||||
|
|
||||||
fn (p mut Parser) fn_decl() ast.FnDecl {
|
fn (p mut Parser) fn_decl() ast.FnDecl {
|
||||||
is_pub := p.tok.kind == .key_pub
|
is_pub := p.tok.kind == .key_pub
|
||||||
if is_pub {
|
if is_pub {
|
||||||
|
|
|
@ -314,7 +314,7 @@ pub fn (p mut Parser) expr(precedence int) (ast.Expr,types.TypeIdent) {
|
||||||
node,ti = p.name_expr()
|
node,ti = p.name_expr()
|
||||||
}
|
}
|
||||||
.str {
|
.str {
|
||||||
node,ti = p.parse_string_literal()
|
node,ti = p.string_expr()
|
||||||
}
|
}
|
||||||
// -1, -a etc
|
// -1, -a etc
|
||||||
.minus {
|
.minus {
|
||||||
|
@ -332,7 +332,6 @@ pub fn (p mut Parser) expr(precedence int) (ast.Expr,types.TypeIdent) {
|
||||||
}
|
}
|
||||||
.lpar {
|
.lpar {
|
||||||
p.check(.lpar)
|
p.check(.lpar)
|
||||||
p.next()
|
|
||||||
node,ti = p.expr(0)
|
node,ti = p.expr(0)
|
||||||
p.check(.rpar)
|
p.check(.rpar)
|
||||||
}
|
}
|
||||||
|
@ -387,6 +386,19 @@ fn (p mut Parser) prefix_expr() (ast.Expr,types.TypeIdent) {
|
||||||
fn (p mut Parser) dot_expr(left ast.Expr) (ast.Expr,types.TypeIdent) {
|
fn (p mut Parser) dot_expr(left ast.Expr) (ast.Expr,types.TypeIdent) {
|
||||||
p.next()
|
p.next()
|
||||||
field_name := p.check_name()
|
field_name := p.check_name()
|
||||||
|
// Method call
|
||||||
|
if p.tok.kind == .lpar {
|
||||||
|
p.next()
|
||||||
|
args := p.call_args()
|
||||||
|
println('method call $field_name')
|
||||||
|
mut node := ast.Expr{}
|
||||||
|
node = ast.MethodCallExpr{
|
||||||
|
expr: left
|
||||||
|
name: field_name
|
||||||
|
args: args
|
||||||
|
}
|
||||||
|
return node,types.int_ti
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
// p.next()
|
// p.next()
|
||||||
field := p.check_name()
|
field := p.check_name()
|
||||||
|
@ -555,12 +567,24 @@ fn (p mut Parser) if_expr() (ast.Expr,types.TypeIdent) {
|
||||||
return node,ti
|
return node,ti
|
||||||
}
|
}
|
||||||
|
|
||||||
fn (p mut Parser) parse_string_literal() (ast.Expr,types.TypeIdent) {
|
fn (p mut Parser) string_expr() (ast.Expr,types.TypeIdent) {
|
||||||
mut node := ast.Expr{}
|
mut node := ast.Expr{}
|
||||||
node = ast.StringLiteral{
|
node = ast.StringLiteral{
|
||||||
val: p.tok.lit
|
val: p.tok.lit
|
||||||
}
|
}
|
||||||
p.next()
|
if p.peek_tok.kind != .str_dollar {
|
||||||
|
p.next()
|
||||||
|
return node,types.string_ti
|
||||||
|
}
|
||||||
|
// Handle $ interpolation
|
||||||
|
for p.tok.kind == .str {
|
||||||
|
p.next()
|
||||||
|
if p.tok.kind != .str_dollar {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
p.check(.str_dollar)
|
||||||
|
p.expr(0)
|
||||||
|
}
|
||||||
return node,types.string_ti
|
return node,types.string_ti
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -677,7 +701,7 @@ fn (p mut Parser) return_stmt() ast.Return {
|
||||||
p.next()
|
p.next()
|
||||||
expr,t := p.expr(0)
|
expr,t := p.expr(0)
|
||||||
if !types.check(p.return_ti, t) {
|
if !types.check(p.return_ti, t) {
|
||||||
p.error('cannot use `$t.name` as type `$p.return_ti.name` in return argument')
|
p.warn('cannot use `$t.name` as type `$p.return_ti.name` in return argument')
|
||||||
}
|
}
|
||||||
return ast.Return{
|
return ast.Return{
|
||||||
expr: expr
|
expr: expr
|
||||||
|
|
Loading…
Reference in New Issue