16 from joy.utils.types import (
17 doc_from_stack_effect,
37 fi, fo = infer(pop, swap, rolldown, rrest, ccons)[0]
40 25 (--) ∘ pop swap rolldown rrest ccons
41 28 (a1 --) ∘ swap rolldown rrest ccons
42 31 (a3 a2 a1 -- a2 a3) ∘ rolldown rrest ccons
43 34 (a4 a3 a2 a1 -- a2 a3 a4) ∘ rrest ccons
44 37 ([a4 a5 ...1] a3 a2 a1 -- a2 a3 [...1]) ∘ ccons
45 40 ([a4 a5 ...1] a3 a2 a1 -- [a2 a3 ...1]) ∘
50 print doc_from_stack_effect(fi, fo)
53 ([a4 a5 ...1] a3 a2 a1 -- [a2 a3 ...1])
58 from joy.parser import text_to_expression
59 from joy.utils.stack import stack_to_string
65 e = text_to_expression('0 1 2 [3 4]') # reverse order
66 print stack_to_string(e)
81 {a1: 0, a2: 1, a3: 2, a4: 3, a5: 4, s2: (), s1: ()}
87 g = reify(u, (fi, fo))
88 print doc_from_stack_effect(*g)
91 (... [3 4 ] 2 1 0 -- ... [1 2 ])
94 ## Unification Works "in Reverse"
98 e = text_to_expression('[2 3]')
103 u = unify(e, fo)[0] # output side, not input side
110 {a2: 2, a3: 3, s2: (), s1: ()}
116 g = reify(u, (fi, fo))
117 print doc_from_stack_effect(*g)
120 (... [a4 a5 ] 3 2 a1 -- ... [2 3 ])
127 fi, fo = infer(dup, mul)[0]
131 28 (a1 -- a1 a1) ∘ mul
138 e = text_to_expression('"two"')
139 print stack_to_string(e)
149 except JoyTypeError, err:
153 Cannot unify 'two' and f1.