Wed, 31 Dec 2014 06:09:35 +0100
Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.
michael@0 | 1 | // Church-Peano integers |
michael@0 | 2 | |
michael@0 | 3 | var Zero = f => x => x; |
michael@0 | 4 | var Succ = n => f => x => n(f)(f(x)); |
michael@0 | 5 | var Add = a => b => f => x => a(f)(b(f)(x)); |
michael@0 | 6 | var Mul = a => b => f => x => a(b(f))(x); |
michael@0 | 7 | var Exp = a => b => b(a); |
michael@0 | 8 | |
michael@0 | 9 | var n = f => f(k => k + 1)(0); |
michael@0 | 10 | |
michael@0 | 11 | assertEq(n(Zero), 0); |
michael@0 | 12 | assertEq(n(Succ(Zero)), 1); |
michael@0 | 13 | assertEq(n(Succ(Succ(Zero))), 2); |
michael@0 | 14 | |
michael@0 | 15 | var Three = Succ(Succ(Succ(Zero))); |
michael@0 | 16 | var Five = Succ(Succ(Three)); |
michael@0 | 17 | assertEq(n(Add(Three)(Five)), 8); |
michael@0 | 18 | assertEq(n(Mul(Three)(Five)), 15); |
michael@0 | 19 | assertEq(n(Exp(Three)(Five)), 243); |