; To demonstrate tangle directives, we'll construct a factorial function with ; separate base and recursive cases. Compare factorial.mu. ; This isn't a very realistic example, just a simple demonstration of ; possibilities. (function factorial [ ((default-scope scope-address) <- new (scope literal) (30 literal)) ((n integer) <- next-input) { begin base-case } recursive-case ]) (after base-case [ ; if n=0 return 1 ((zero? boolean) <- equal (n integer) (0 literal)) (break-unless (zero? boolean)) (reply (1 literal)) ]) (after recursive-case [ ; return n*factorial(n-1) ((x integer) <- subtract (n integer) (1 literal)) ((subresult integer) <- factorial (x integer)) ((result integer) <- multiply (subresult integer) (n integer)) (reply (result integer)) ]) (function main [ ((1 integer) <- factorial (5 literal)) (print-primitive ("result: " literal)) (print-primitive (1 integer)) (print-primitive ("\n" literal)) ])