1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
--- parse tree ---
[ Code
"test/typ/compiler/recursion-05.typ"
( line 1 , column 2 )
(Let
(BasicBind (Just (Identifier "test")))
(FuncExpr
[ NormalParam (Identifier "x") , NormalParam (Identifier "y") ]
(Block
(CodeBlock
[ If
[ ( Equals (Ident (Identifier "x")) (Ident (Identifier "y"))
, Block (Content [ Text "\9989" ])
)
, ( Literal (Boolean True)
, Block
(Content
[ Text "\10060"
, Text "("
, Code
"test/typ/compiler/recursion-05.typ"
( line 1 , column 47 )
(FuncCall
(Ident (Identifier "repr"))
[ NormalArg (Ident (Identifier "x")) ])
, Space
, Text "/"
, Text "="
, Space
, Code
"test/typ/compiler/recursion-05.typ"
( line 1 , column 59 )
(FuncCall
(Ident (Identifier "repr"))
[ NormalArg (Ident (Identifier "y")) ])
, Text ")"
])
)
]
]))))
, SoftBreak
, Code
"test/typ/compiler/recursion-05.typ"
( line 2 , column 2 )
(LetFunc
(Identifier "f")
[ NormalParam (Identifier "x") ]
(Literal (String "hello")))
, SoftBreak
, Code
"test/typ/compiler/recursion-05.typ"
( line 3 , column 2 )
(LetFunc
(Identifier "f")
[ NormalParam (Identifier "x") ]
(If
[ ( Not (Equals (Ident (Identifier "x")) (Literal None))
, Block
(CodeBlock
[ FuncCall (Ident (Identifier "f")) [ NormalArg (Literal None) ] ])
)
, ( Literal (Boolean True)
, Block (CodeBlock [ Literal (String "world") ])
)
]))
, SoftBreak
, Code
"test/typ/compiler/recursion-05.typ"
( line 4 , column 2 )
(FuncCall
(Ident (Identifier "test"))
[ NormalArg
(FuncCall (Ident (Identifier "f")) [ NormalArg (Literal (Int 1)) ])
, NormalArg (Literal (String "world"))
])
, ParBreak
]
--- evaluated ---
document(body: { text(body: [
]),
text(body: [
]),
text(body: [
]),
text(body: [✅]),
parbreak() })
|