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 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
|
--- parse tree ---
[ Code
"test/typ/compiler/spread-03.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/spread-03.typ"
( line 1 , column 47 )
(FuncCall
(Ident (Identifier "repr"))
[ NormalArg (Ident (Identifier "x")) ])
, Space
, Text "/"
, Text "="
, Space
, Code
"test/typ/compiler/spread-03.typ"
( line 1 , column 59 )
(FuncCall
(Ident (Identifier "repr"))
[ NormalArg (Ident (Identifier "y")) ])
, Text ")"
])
)
]
]))))
, SoftBreak
, Comment
, Code
"test/typ/compiler/spread-03.typ"
( line 3 , column 2 )
(Block
(CodeBlock
[ Let
(BasicBind (Just (Identifier "more")))
(Array
[ Reg (Literal (Int 3))
, Reg (Negated (Literal (Int 3)))
, Reg (Literal (Int 6))
, Reg (Literal (Int 10))
])
, FuncCall
(Ident (Identifier "test"))
[ NormalArg
(FuncCall
(FieldAccess
(Ident (Identifier "min")) (Ident (Identifier "calc")))
[ NormalArg (Literal (Int 1))
, NormalArg (Literal (Int 2))
, SpreadArg (Ident (Identifier "more"))
])
, NormalArg (Negated (Literal (Int 3)))
]
, FuncCall
(Ident (Identifier "test"))
[ NormalArg
(FuncCall
(FieldAccess
(Ident (Identifier "max")) (Ident (Identifier "calc")))
[ SpreadArg (Ident (Identifier "more"))
, NormalArg (Literal (Int 9))
])
, NormalArg (Literal (Int 10))
]
, FuncCall
(Ident (Identifier "test"))
[ NormalArg
(FuncCall
(FieldAccess
(Ident (Identifier "max")) (Ident (Identifier "calc")))
[ SpreadArg (Ident (Identifier "more"))
, NormalArg (Literal (Int 11))
])
, NormalArg (Literal (Int 11))
]
]))
, ParBreak
, Code
"test/typ/compiler/spread-03.typ"
( line 10 , column 2 )
(Block
(CodeBlock
[ Let
(BasicBind (Just (Identifier "more")))
(Dict
[ Reg ( Ident (Identifier "c") , Literal (Int 3) )
, Reg ( Ident (Identifier "d") , Literal (Int 4) )
])
, LetFunc
(Identifier "tostr")
[ SinkParam (Just (Identifier "args")) ]
(FuncCall
(Ident (Identifier "repr"))
[ NormalArg (Ident (Identifier "args")) ])
, FuncCall
(Ident (Identifier "test"))
[ NormalArg
(FuncCall
(Ident (Identifier "tostr"))
[ KeyValArg (Identifier "a") (Literal (Int 1))
, SpreadArg (Ident (Identifier "more"))
, KeyValArg (Identifier "b") (Literal (Int 2))
])
, NormalArg (Literal (String "(a: 1, c: 3, d: 4, b: 2)"))
]
]))
, ParBreak
]
--- evaluated ---
document(body: { text(body: [
]),
text(body: [✅]),
text(body: [✅]),
text(body: [✅]),
parbreak(),
text(body: [✅]),
parbreak() })
|