v2: process `or` block for `CallExpr`
parent
efff66ada7
commit
ee0a0afb25
|
@ -154,6 +154,7 @@ mut:
|
|||
args []Expr
|
||||
is_c bool
|
||||
muts []bool
|
||||
or_block OrExpr
|
||||
}
|
||||
|
||||
pub struct MethodCallExpr {
|
||||
|
|
|
@ -324,16 +324,24 @@ fn (f mut Fmt) expr(node ast.Expr) {
|
|||
}
|
||||
ast.CallExpr {
|
||||
f.write('${it.name}(')
|
||||
for i, expr in it.args {
|
||||
for i, arg in it.args {
|
||||
if it.muts[i] {
|
||||
f.write('mut ')
|
||||
}
|
||||
f.expr(expr)
|
||||
if i != it.args.len - 1 {
|
||||
if i > 0 {
|
||||
f.wrap_long_line()
|
||||
}
|
||||
f.expr(arg)
|
||||
if i < it.args.len - 1 {
|
||||
f.write(', ')
|
||||
}
|
||||
}
|
||||
f.write(')')
|
||||
if it.or_block.stmts.len > 0 {
|
||||
f.writeln(' or {')
|
||||
f.stmts(it.or_block.stmts)
|
||||
f.write('}')
|
||||
}
|
||||
}
|
||||
ast.CharLiteral {
|
||||
f.write('`$it.val`')
|
||||
|
|
|
@ -138,3 +138,17 @@ fn unsafe_fn() {
|
|||
malloc(2)
|
||||
}
|
||||
}
|
||||
|
||||
fn fn_with_or() int {
|
||||
fn_with_optional() or {
|
||||
return 10
|
||||
}
|
||||
return 20
|
||||
}
|
||||
|
||||
fn (f Foo) method_with_or() int {
|
||||
f.fn_with_optional() or {
|
||||
return 10
|
||||
}
|
||||
return 20
|
||||
}
|
||||
|
|
|
@ -138,3 +138,17 @@ fn fn_with_multi_return() (int,string) {
|
|||
fn unsafe_fn() {
|
||||
unsafe { malloc(2) }
|
||||
}
|
||||
|
||||
fn fn_with_or() int {
|
||||
fn_with_optional() or {
|
||||
return 10
|
||||
}
|
||||
return 20
|
||||
}
|
||||
|
||||
fn (f Foo) method_with_or() int {
|
||||
f.fn_with_optional() or {
|
||||
return 10
|
||||
}
|
||||
return 20
|
||||
}
|
||||
|
|
|
@ -14,6 +14,11 @@ pub fn (p mut Parser) call_expr(is_c bool, mod string) ast.CallExpr {
|
|||
fn_name := if is_c {'C.$name' } else if mod.len > 0 { '${mod}.$name' } else { name }
|
||||
p.check(.lpar)
|
||||
args, muts := p.call_args()
|
||||
mut or_stmts := []ast.Stmt
|
||||
if p.tok.kind == .key_orelse {
|
||||
p.next()
|
||||
or_stmts = p.parse_block()
|
||||
}
|
||||
node := ast.CallExpr{
|
||||
name: fn_name
|
||||
args: args
|
||||
|
@ -22,10 +27,9 @@ pub fn (p mut Parser) call_expr(is_c bool, mod string) ast.CallExpr {
|
|||
|
||||
pos: tok.position()
|
||||
is_c: is_c
|
||||
or_block: ast.OrExpr{
|
||||
stmts: or_stmts
|
||||
}
|
||||
if p.tok.kind == .key_orelse {
|
||||
p.next()
|
||||
p.parse_block()
|
||||
}
|
||||
return node
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue