lang: funcs, parser: Add improved panic magic
This is a newer implementation of the panic magic. I kept the old commit in for posterity and to show the difference. The two versions are identical to the end-user with one exception: the newer version doesn't include a useless panic resource in the graph when there is no panic. In this version, the panic function returns false and the if statement it's the condition of, doesn't produce the resource within. On error, we still consume the function in the if expression, and doing so causes everything to shutdown. The other benefit is that the implementation is much cleaner and doesn't need the interpolate hack.
This commit is contained in:
@@ -927,17 +927,30 @@ bind:
|
||||
;
|
||||
panic:
|
||||
// panic("some error")
|
||||
// generates:
|
||||
// if panic("some error") {
|
||||
// _panic "_panic" {} # resource
|
||||
//}
|
||||
PANIC_IDENTIFIER OPEN_PAREN call_args CLOSE_PAREN
|
||||
{
|
||||
posLast(yylex, yyDollar) // our pos
|
||||
call := &ast.ExprCall{
|
||||
Name: $1.str,
|
||||
Name: $1.str, // the function name
|
||||
Args: $3.exprs,
|
||||
//Var: false, // default
|
||||
}
|
||||
$$.stmt = &ast.StmtBind{
|
||||
Ident: interfaces.PanicVarName, // make up a placeholder var
|
||||
Value: call,
|
||||
name := &ast.ExprStr{
|
||||
V: $1.str, // any constant, non-empty name
|
||||
}
|
||||
res := &ast.StmtRes{
|
||||
Kind: interfaces.PanicResKind,
|
||||
Name: name,
|
||||
Contents: []ast.StmtResContents{},
|
||||
}
|
||||
$$.stmt = &ast.StmtIf{
|
||||
Condition: call,
|
||||
ThenBranch: res,
|
||||
//ElseBranch: nil,
|
||||
}
|
||||
}
|
||||
;
|
||||
|
||||
Reference in New Issue
Block a user