From e33e182eb0ff980a9b4bd7a7a2464e091a7ff84e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Josef=20Pospi=CC=81s=CC=8Cil?= Date: Wed, 4 Nov 2020 10:16:02 +0100 Subject: [PATCH] Fix assembly example --- examples/assembly.janet | 33 ++++++++++++++++----------------- 1 file changed, 16 insertions(+), 17 deletions(-) diff --git a/examples/assembly.janet b/examples/assembly.janet index 8f74e1c2..ab3292c7 100644 --- a/examples/assembly.janet +++ b/examples/assembly.janet @@ -1,23 +1,22 @@ # Example of dst bytecode assembly # Fibonacci sequence, implemented with naive recursion. -(def fibasm (asm '{ - arity 1 - bytecode [ - (ltim 1 0 0x2) # $1 = $0 < 2 - (jmpif 1 :done) # if ($1) goto :done - (lds 1) # $1 = self - (addim 0 0 -0x1) # $0 = $0 - 1 - (push 0) # push($0), push argument for next function call - (call 2 1) # $2 = call($1) - (addim 0 0 -0x1) # $0 = $0 - 1 - (push 0) # push($0) - (call 0 1) # $0 = call($1) - (add 0 0 2) # $0 = $0 + $2 (integers) - :done - (ret 0) # return $0 - ] -})) +(def fibasm + (asm + '{:arity 1 + :bytecode @[(ltim 1 0 0x2) # $1 = $0 < 2 + (jmpif 1 :done) # if ($1) goto :done + (lds 1) # $1 = self + (addim 0 0 -0x1) # $0 = $0 - 1 + (push 0) # push($0), push argument for next function call + (call 2 1) # $2 = call($1) + (addim 0 0 -0x1) # $0 = $0 - 1 + (push 0) # push($0) + (call 0 1) # $0 = call($1) + (add 0 0 2) # $0 = $0 + $2 (integers) + :done + (ret 0) # return $0 +]})) # Test it