1
1
mirror of https://github.com/anoma/juvix.git synced 2025-01-07 08:08:44 +03:00

Update juvix-stdlib to remove non-ASCII indentifiers (#2857)

This PR updates the juvix-stdlib to the current main commit which
includes:

* https://github.com/anoma/juvix-stdlib/issues/59
* https://github.com/anoma/juvix-stdlib/issues/101

All the Juvix test suite files and examples in this repo have been
updated to be compatible with the new stdlib.
This commit is contained in:
Paul Cadman 2024-06-26 09:23:35 +01:00 committed by GitHub
parent 6d24d7186d
commit b8cd84170b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
149 changed files with 520 additions and 520 deletions

View File

@ -43,11 +43,11 @@ sort {A} {{Ord A}} : List A → List A
printNatListLn : List Nat → IO
| nil := printStringLn "nil"
| (x :: xs) :=
printNat x >> printString " :: " >> printNatListLn xs;
printNat x >>> printString " :: " >>> printNatListLn xs;
main : IO :=
printStringLn "Hello!"
>> printNatListLn (preorder (mirror tree))
>> printNatListLn (sort (preorder (mirror tree)))
>> printNatLn (log2 3)
>> printNatLn (log2 130);
>>> printNatListLn (preorder (mirror tree))
>>> printNatListLn (sort (preorder (mirror tree)))
>>> printNatLn (log2 3)
>>> printNatLn (log2 130);

View File

@ -34,7 +34,7 @@ open Token;
--- This module defines the type for balances and its associated operations.
module Balances;
Balances : Type := List (Field × Nat);
Balances : Type := List (Pair Field Nat);
--- Increments the amount associated with a certain ;Field;.
increment : Field -> Nat -> Balances -> Balances

View File

@ -12,8 +12,8 @@ collatz : Nat → Nat
terminating
run (f : Nat → Nat) : Nat → IO
| (suc zero) := printNatLn 1 >> printStringLn "Finished!"
| n := printNatLn n >> run f (f n);
| (suc zero) := printNatLn 1 >>> printStringLn "Finished!"
| n := printNatLn n >>> run f (f n);
welcome : String :=
"Collatz calculator\n------------------\n\nType a number then ENTER";
@ -22,7 +22,7 @@ resultHeading : String := "Collatz sequence:";
main : IO :=
printStringLn welcome
>> readLn
>>> readLn
λ {s :=
printStringLn resultHeading
>> run collatz (stringToNat s)};
>>> run collatz (stringToNat s)};

View File

@ -8,4 +8,5 @@ fib : Nat → Nat → Nat → Nat
fibonacci (n : Nat) : Nat := fib n 0 1;
main : IO := readLn (printNatLn ∘ fibonacci ∘ stringToNat);
main : IO :=
readLn (stringToNat >> fibonacci >> printNatLn);

View File

@ -17,7 +17,7 @@ prompt (x : GameState) : String :=
++str ": ";
nextMove (s : GameState) : String → GameState :=
flip playMove s ∘ validMove ∘ stringToNat;
stringToNat >> validMove >> flip playMove s;
--- Main loop
terminating
@ -30,12 +30,13 @@ run : GameState → IO
++str msg)
| (state b p (continue msg)) :=
printString (msg ++str prompt (state b p noError))
>> readLn (run ∘ nextMove (state b p noError))
| x := printString (prompt x) >> readLn (run ∘ nextMove x);
>>> readLn (run << nextMove (state b p noError))
| x :=
printString (prompt x) >>> readLn (run << nextMove x);
--- The welcome message
welcome : String :=
"MiniTicTacToe\n-------------\n\nType a number then ENTER to make a move";
--- The entry point of the program
main : IO := printStringLn welcome >> run beginState;
main : IO := printStringLn welcome >>> run beginState;

@ -1 +1 @@
Subproject commit 73ecbc57738f4bde6f4f39636436ba38504b33f6
Subproject commit 00f6f503dbc2cfa72bd469fb8ce7edd0e9730639

View File

@ -327,7 +327,7 @@ tests =
$(mkRelFile "test050.juvix")
$(mkRelFile "out/test050.out"),
posTest
"Test051: Local recursive function using IO >>"
"Test051: Local recursive function using IO >>>"
$(mkRelDir ".")
$(mkRelFile "test051.juvix")
$(mkRelFile "out/test051.out"),

View File

@ -14,7 +14,7 @@ import Stdlib.Debug.Trace open;
main : Nat :=
trace (mod 3 2)
>>> trace (div 18 4)
>>> trace (mod 18 4)
>>> trace (div 16 4)
>>> mod 16 4;
>-> trace (div 18 4)
>-> trace (mod 18 4)
>-> trace (div 16 4)
>-> mod 16 4;

View File

@ -10,5 +10,5 @@ loop : Nat := loop;
main : Bool :=
trace
(if (3 > 0) 1 loop + if (2 < 1) loop (if (7 >= 8) loop 1))
>>> trace (2 > 0 || loop == 0)
>>> 2 < 0 && loop == 0;
>-> trace (2 > 0 || loop == 0)
>-> 2 < 0 && loop == 0;

View File

@ -20,11 +20,11 @@ lst : List Nat := 0 :: 1 :: nil;
main : List Nat :=
trace (null lst)
>>> trace (null (nil {Nat}))
>>> trace (head 1 lst)
>>> trace (tail lst)
>>> trace (head 0 (tail lst))
>>> trace (map ((+) 1) lst)
>>> map' ((+) 1) lst
>-> trace (null (nil {Nat}))
>-> trace (head 1 lst)
>-> trace (tail lst)
>-> trace (head 0 (tail lst))
>-> trace (map ((+) 1) lst)
>-> map' ((+) 1) lst
-- TODO: Restore when anoma backend supports strings
-- >>> runPartial λ {{{_}} := map'' ((+) 1) lst};
-- >-> runPartial λ {{{_}} := map'' ((+) 1) lst};

View File

@ -18,6 +18,6 @@ fact : Nat → Nat := fact' 1;
main (n : Nat) : Nat :=
trace (sum n)
>>> trace (fact 5)
>>> trace (fact 10)
>>> fact 12;
>-> trace (fact 5)
>-> trace (fact 10)
>-> fact 12;

View File

@ -12,5 +12,5 @@ fib : Nat → Nat := fib' 0 1;
main : Nat :=
trace (fib 10)
>>> trace (fib 100)
>>> fib 1000;
>-> trace (fib 100)
>-> fib 1000;

View File

@ -32,7 +32,7 @@ combineDigits (xs : List Nat) : Nat := for (acc := 0) (x in xs) acc * 10 + x;
main : Nat :=
trace (combineDigits (preorder (gen 3)))
>>> trace (combineDigits (preorder (gen 4)))
>>> trace (combineDigits (preorder (gen 5)))
>>> trace (combineDigits (preorder (gen 6)))
>>> combineDigits (preorder (gen 7));
>-> trace (combineDigits (preorder (gen 4)))
>-> trace (combineDigits (preorder (gen 5)))
>-> trace (combineDigits (preorder (gen 6)))
>-> combineDigits (preorder (gen 7));

View File

@ -16,6 +16,6 @@ f : Nat → Nat → Nat
main : Nat :=
trace (f 5 6)
>>> trace (f 6 5)
>>> trace (f 10 5)
>>> f 11 5;
>-> trace (f 6 5)
>-> trace (f 10 5)
>-> f 11 5;

View File

@ -24,13 +24,13 @@ vy : Nat := 7;
main : Nat :=
trace (func (div y x))
>>> -- 17 div 5 + 4 = 7
>-> -- 17 div 5 + 4 = 7
trace
(y + x * z)
>>> -- 17
>-> -- 17
trace
(vx + vy * (z + 1))
>>> -- 37
>-> -- 37
f
(h g 2 3)
4;

View File

@ -23,19 +23,19 @@ h : Nat → Nat
main : Nat :=
trace (f 100 500)
>>> -- 600
>-> -- 600
trace
(f 5 0)
>>> -- 25
>-> -- 25
trace
(f 5 5)
>>> -- 30
>-> -- 30
trace
(h 10)
>>> -- 45
>-> -- 45
trace
(g 10 h)
>>> -- 55
>-> -- 55
g
3
(f 10);

View File

@ -16,11 +16,11 @@ subp : Nat → Nat → Nat
main : Nat :=
trace (f91 101)
>>> trace (f91 95)
>>> trace (f91 16)
>>> trace (f91 5)
>>> trace (subp 101 1)
>>> trace (subp 11 5)
>>> trace (subp 10 4)
>>> trace (subp 1000 600)
>>> subp 10000 6000;
>-> trace (f91 95)
>-> trace (f91 16)
>-> trace (f91 5)
>-> trace (subp 101 1)
>-> trace (subp 11 5)
>-> trace (subp 10 4)
>-> trace (subp 1000 600)
>-> subp 10000 6000;

View File

@ -18,4 +18,4 @@ power' : Nat → Nat → Nat → Nat
power : Nat → Nat → Nat := power' 1;
main : Nat :=
trace (power 2 3) >>> trace (power 3 7) >>> power 5 11;
trace (power 2 3) >-> trace (power 3 7) >-> power 5 11;

View File

@ -17,12 +17,12 @@ sum' : Nat → Nat
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (h :: t) :=
printNat h >> printString " :: " >> printListNatLn t;
printNat h >>> printString " :: " >>> printListNatLn t;
main (n : Nat) : Nat :=
trace (gen 10)
>>> trace (reverse (gen 10))
>>> trace (filter ((<) 5) (gen 10))
>>> trace (reverse (map (flip sub 1) (gen 10)))
>>> trace (sum n)
>>> sum' n;
>-> trace (reverse (gen 10))
>-> trace (filter ((<) 5) (gen 10))
>-> trace (reverse (map (flip sub 1) (gen 10)))
>-> trace (sum n)
>-> sum' n;

View File

@ -17,4 +17,4 @@ terminating
h : Nat → Nat
| x := if (x < 1) 1 (x * f (sub x 1));
main : Nat := trace (f 5) >>> trace (f 10) >>> f 20;
main : Nat := trace (f 5) >-> trace (f 10) >-> f 20;

View File

@ -11,7 +11,7 @@ gcd : Nat → Nat → Nat
main : Nat :=
trace (gcd (3 * 7 * 2) (7 * 2 * 11))
>>> trace (gcd (3 * 7 * 2 * 11 * 5) (7 * 2 * 5))
>>> trace (gcd 3 7)
>>> trace (gcd 7 3)
>>> gcd (11 * 7 * 3) (2 * 5 * 13);
>-> trace (gcd (3 * 7 * 2 * 11 * 5) (7 * 2 * 5))
>-> trace (gcd 3 7)
>-> trace (gcd 7 3)
>-> gcd (11 * 7 * 3) (2 * 5 * 13);

View File

@ -30,7 +30,7 @@ drop_front : {A : Type} → Queue A → Queue A
| nil := queue (reverse (qsnd q')) nil
| _ := q';
pop_front {A} : Queue A -> Maybe (A × Queue A)
pop_front {A} : Queue A -> Maybe (Pair A (Queue A))
| (queue xs ys) :=
case xs of
| h :: t := just (h, queue t ys)

View File

@ -10,17 +10,17 @@ czero : Num
| {_} f x := x;
csuc : Num → Num
| n {_} f := f n {_} f;
| n {_} f := f << n {_} f;
num : Nat → Num
| zero := czero
| (suc n) := csuc (num n);
add : Num → Num → Num
| n m {_} f := n {_} f m {_} f;
| n m {_} f := n {_} f << m {_} f;
mul : Num → Num → Num
| n m {_} := n {_} m {_};
| n m {_} := n {_} << m {_};
isZero : Num → Bool
| n := n {_} (const false) true;
@ -30,5 +30,5 @@ toNat : Num → Nat
main : Nat :=
trace (toNat (num 7))
>>> trace (toNat (add (num 7) (num 3)))
>>> toNat (mul (num 7) (num 3));
>-> trace (toNat (add (num 7) (num 3)))
>-> toNat (mul (num 7) (num 3));

View File

@ -45,4 +45,4 @@ primes : Unit → Stream := eratostenes (numbers 2);
main (n1 n2 : Nat) : Nat :=
trace (snth n1 primes)
>>> snth n2 primes;
>-> snth n2 primes;

View File

@ -11,7 +11,7 @@ ack : Nat → Nat → Nat
main : Nat :=
trace (ack 0 7)
>>> trace (ack 1 7)
>>> trace (ack 1 13)
>>> trace (ack 2 7)
>>> ack 2 13;
>-> trace (ack 1 7)
>-> trace (ack 1 13)
>-> trace (ack 2 7)
>-> ack 2 13;

View File

@ -8,7 +8,7 @@ iterate : {A : Type} → (A → A) → Nat → A → A
-- clauses with differing number of patterns not yet supported
-- iterate f zero x := x;
| f zero := id
| f (suc n) := f iterate f n;
| f (suc n) := f << iterate f n;
plus : Nat → Nat → Nat := iterate suc;
@ -23,6 +23,6 @@ ackermann : Nat → Nat → Nat
main : Nat :=
trace (plus 3 7)
>>> trace (mult 3 7)
>>> trace (exp 3 7)
>>> ackermann 1 13;
>-> trace (mult 3 7)
>-> trace (exp 3 7)
>-> ackermann 1 13;

View File

@ -4,7 +4,7 @@ module test032;
import Stdlib.Prelude open;
import Stdlib.Debug.Trace open;
split : {A : Type} → Nat → List A → List A × List A
split : {A : Type} → Nat → List A → Pair (List A) (List A)
| zero xs := nil, xs
| (suc n) nil := nil, nil
| (suc n) (x :: xs) :=
@ -46,5 +46,5 @@ gen2 : List (List Nat) → Nat → Nat → List (List Nat)
main : List Nat :=
trace (take 10 (uniq (sort (flatten (gen2 nil 6 10)))))
>>> trace (take 10 (uniq (sort (flatten (gen2 nil 7 10)))))
>>> take 10 (uniq (sort (flatten (gen2 nil 6 20))));
>-> trace (take 10 (uniq (sort (flatten (gen2 nil 7 10)))))
>-> take 10 (uniq (sort (flatten (gen2 nil 6 20))));

View File

@ -10,24 +10,24 @@ f : (Nat → Nat) → Nat
f' : Nat → Nat
| x := f ((+) x);
g : (Nat → Nat × Nat) → Nat × Nat
g : (Nat → Pair Nat Nat) → Pair Nat Nat
| f := f 2;
g' : Nat → Nat × Nat
g' : Nat → Pair Nat Nat
| x := g ((,) x);
f1' : Nat → Nat → Nat
| x y := f ((+) (div x y));
g1' : Nat → Nat → Nat × Nat
g1' : Nat → Nat → Pair Nat Nat
| x y := g ((,) (div x y));
h : (Nat → Nat → Nat × Nat) → Nat × Nat
h : (Nat → Nat → Pair Nat Nat) → Pair Nat Nat
| f := f 1 2;
main : Nat × Nat :=
main : Pair Nat Nat :=
trace (f' 7)
>>> trace (g' 7)
>>> trace (f1' 7 2)
>>> trace (g1' 7 2)
>>> h (,);
>-> trace (g' 7)
>-> trace (f1' 7 2)
>-> trace (g1' 7 2)
>-> h (,);

View File

@ -22,8 +22,8 @@ mutrec : Nat :=
terminating
h (x : Nat) : Nat := if (x < 1) 1 (x * f (sub x 1));
in trace (f 5)
>>> trace (f 10)
>>> trace (g 5)
>>> h 5;
>-> trace (f 10)
>-> trace (g 5)
>-> h 5;
main : Nat := trace (sum 1000) >>> mutrec;
main : Nat := trace (sum 1000) >-> mutrec;

View File

@ -43,8 +43,8 @@ h : Nat -> Nat
main : Nat :=
trace (sum2 (lgen 5))
>>> trace (f (gen 10))
>>> trace (f (gen 15))
>>> trace (f (gen 16))
>>> trace (h 5)
>>> h 3;
>-> trace (f (gen 10))
>-> trace (f (gen 15))
>-> trace (f (gen 16))
>-> trace (h 5)
>-> h 3;

View File

@ -9,12 +9,12 @@ expand : {A : Type} → A → Nat → A
f : Nat → Nat := suc;
g : Nat → Nat → Nat
| z := f flip sub z;
| z := f << flip sub z;
g' : Nat → Nat → Nat
| z := f λ {x := sub x z};
| z := f << λ {x := sub x z};
h : Nat → Nat := f g 3;
h : Nat → Nat := f << g 3;
j : Nat → Nat → Nat := g';

View File

@ -15,4 +15,4 @@ main : Bool :=
| zero := true
| (suc n) := not (odd n);
plusOne (n : Ty) : Ty := n + 1;
in trace (odd (plusOne 13)) >>> even (plusOne 12);
in trace (odd (plusOne 13)) >-> even (plusOne 12);

View File

@ -10,22 +10,22 @@ f : Int -> Nat
main : Int :=
trace (ofNat 1)
>>> trace (ofNat (suc zero))
>>> trace (f -1)
>>> trace (f (ofNat (suc zero)))
>>> trace (f (negSuc (suc zero)))
>>> trace (1 == -1)
>>> trace (neg -1)
>>> trace
>-> trace (ofNat (suc zero))
>-> trace (f -1)
>-> trace (f (ofNat (suc zero)))
>-> trace (f (negSuc (suc zero)))
>-> trace (1 == -1)
>-> trace (neg -1)
>-> trace
(let
g : Int -> Int := neg;
in g -1)
>>> trace (-2 * -2)
>>> trace (nonNeg 0)
>>> trace (nonNeg -1)
>>> trace (0 < 0)
>>> trace (0 <= 0)
>>> trace (0 < 1)
>>> trace (-1 <= 0)
>>> trace (mod 4 -3)
>>> div -6 -3;
>-> trace (-2 * -2)
>-> trace (nonNeg 0)
>-> trace (nonNeg -1)
>-> trace (0 < 0)
>-> trace (0 <= 0)
>-> trace (0 < 1)
>-> trace (-1 <= 0)
>-> trace (mod 4 -3)
>-> div -6 -3;

View File

@ -36,12 +36,12 @@ myfor2
syntax iterator myzip2 {init := 2; range := 2};
myzip2
: {A A' B C : Type}
→ (A → A' → B → C → A × A')
→ (A → A' → B → C → Pair A A')
→ A
→ A'
→ List B
→ List C
A × A'
Pair A A'
| f a b xs ys :=
myfor (acc, acc' := a, b) (x, y in zip xs ys)
f acc acc' x y;

View File

@ -3,9 +3,9 @@ module test055;
import Stdlib.Prelude open;
type Pair :=
| pair : Nat -> Nat -> Pair;
type Pair' :=
| pair : Nat -> Nat -> Pair';
main : List (Pair × Nat) × List Pair :=
main : Pair (List (Pair Pair' Nat)) (List Pair') :=
(pair 1 2, 3) :: (pair 2 3, 4) :: nil
, pair 1 2 :: pair 2 3 :: nil;

View File

@ -10,13 +10,13 @@ type Triple (A B C : Type) :=
thd : C
};
type Pair (A B : Type) :=
type Pair' (A B : Type) :=
mkPair {
fst : A;
snd : B
};
mf : Pair (Pair Bool (List Nat)) (List Nat) → Bool
mf : Pair' (Pair' Bool (List Nat)) (List Nat) → Bool
| mkPair@{fst := mkPair@{fst; snd := nil};
snd := zero :: _} := fst
| x := case x of {_ := false};

View File

@ -60,18 +60,18 @@ f5 {A} {{T A}} (n : Nat) (a : A) : Nat := n + T.toNat a;
main : Nat :=
trace (T.toNat true)
>>> trace (f false)
>>> trace (T.toNat 3)
>>> trace (T.toNat (g {Nat}))
>>> trace (T.toNat [true; false])
>>> trace (T.toNat [1; 2; 3])
>>> trace
>-> trace (f false)
>-> trace (T.toNat 3)
>-> trace (T.toNat (g {Nat}))
>-> trace (T.toNat [true; false])
>-> trace (T.toNat [1; 2; 3])
>-> trace
(let
f (_ : Unit) : Nat := 5;
in T.toNat f)
>>> trace (f' [1; 2])
>>> trace (f'' [true; false])
>>> trace (f'3 [just true; nothing; just false])
>>> trace (f'4 [just [1]; nothing; just [2; 3]])
>>> trace (f'3 true)
>>> f5 1 [0; 1; 1];
>-> trace (f' [1; 2])
>-> trace (f'' [true; false])
>-> trace (f'3 [just true; nothing; just false])
>-> trace (f'4 [just [1]; nothing; just [2; 3]])
>-> trace (f'3 true)
>-> f5 1 [0; 1; 1];

View File

@ -78,10 +78,10 @@ h {A} {{U2 A}} : A -> A := f;
main : Nat :=
trace (T1.pp 0)
>>> trace (T2.pp 1)
>>> trace (T3.pp 2)
>>> trace (T4.pp 3)
>>> trace (U.pp 4)
>>> trace (f 5)
>>> trace (g {{mkU1 id}} 6)
>>> h 7;
>-> trace (T2.pp 1)
>-> trace (T3.pp 2)
>-> trace (T4.pp 3)
>-> trace (U.pp 4)
>-> trace (f 5)
>-> trace (g {{mkU1 id}} 6)
>-> h 7;

View File

@ -3,7 +3,7 @@ module test069;
import Stdlib.Data.Nat open hiding {Ord; mkOrd};
import Stdlib.Data.Nat.Ord as Ord;
import Stdlib.Data.Product as Ord;
import Stdlib.Data.Pair as Ord;
import Stdlib.Data.Bool.Base open;
import Stdlib.Trait.Ord open using {Ordering; LT; EQ; GT; isLT; isGT};

View File

@ -3,7 +3,7 @@ module test071;
import Stdlib.Data.Nat open hiding {Ord; mkOrd};
import Stdlib.Data.Nat.Ord as Ord;
import Stdlib.Data.Product as Ord;
import Stdlib.Data.Pair as Ord;
import Stdlib.Data.Bool.Base open;
import Stdlib.Trait.Ord open using {Ordering; LT; EQ; GT; isLT; isGT};

View File

@ -16,6 +16,6 @@ type Monad (f : Type -> Type) :=
open Monad public;
syntax operator >> bind;
>> {M : Type → Type} {A B : Type} {{Monad M}} (x : M
syntax operator >>> bind;
>>> {M : Type → Type} {A B : Type} {{Monad M}} (x : M
A) (y : M B) : M B := x >>= λ {_ := y};

View File

@ -10,7 +10,7 @@ instance
Reader-Functor {R : Type} : Functor (Reader R) :=
mkFunctor@{
<$> {A B : Type} (f : A -> B) : Reader R A -> Reader R B
| (mkReader ra) := mkReader (f ra)
| (mkReader ra) := mkReader (f << ra)
};
instance

View File

@ -52,13 +52,13 @@ ReaderT-MonadReader {S : Type} {M : Type → Type} {{Monad M}}
monad := ReaderT-Monad;
ask : ReaderT S M S := mkReaderT λ {s := MMonad.return s};
reader {A : Type} (f : S → A) : ReaderT S M A :=
mkReaderT (MMonad.return f)
mkReaderT (MMonad.return << f)
};
import MonadState open;
import StateT open;
import Identity open;
import Stdlib.Data.Product open;
import Stdlib.Data.Pair open;
liftReaderT {R A : Type} {M : Type → Type} (m : M A)
: ReaderT R M A := mkReaderT (const m);
@ -76,7 +76,7 @@ askNat {M : Type → Type} {{Monad M}} : ReaderT Nat M Nat :=
monadic : ReaderT Nat (StateT Nat Identity) Nat :=
askNat
>>= λ {n :=
liftReaderT (modify λ {m := m * n}) >> liftReaderT get};
liftReaderT (modify λ {m := m * n}) >>> liftReaderT get};
main : Nat :=
runIdentity (evalState 2 (runReader 5 monadic));
@ -87,6 +87,6 @@ main : Nat :=
-- → Type} {{mreader : MonadReader R M}} : MonadReader R (StateT S M) :=
-- mkMonadReader@{
-- monad := StateT-Monad@{mon := MonadReader.monad {{mreader}}};
-- reader {A : Type} : (R → A) → StateT S M A := liftStateT MonadReader.reader;
-- reader {A : Type} : (R → A) → StateT S M A := liftStateT << MonadReader.reader;
-- ask : StateT S M R := liftStateT MonadReader.ask;
-- };

View File

@ -2,7 +2,7 @@ module State;
import Monad open;
import Functor open;
import Stdlib.Data.Product open;
import Stdlib.Data.Pair open;
type State (S A : Type) := mkState {runState : S -> A × S};

View File

@ -4,15 +4,15 @@ import Monad open;
import Monad open using {module Monad as MMonad};
import Functor open;
import Functor open using {module Functor as MFunctor};
import Stdlib.Data.Product open;
import Stdlib.Data.Pair open;
type StateT (S : Type) (M : Type → Type) (A : Type) :=
mkStateT {runStateT : S → M (A × S)};
mkStateT {runStateT : S → M (Pair A S)};
runState {S A : Type} {M : Type → Type} (s : S) (m : StateT
S
M
A) : M (A × S) := StateT.runStateT m s;
A) : M (Pair A S) := StateT.runStateT m s;
evalState {S A : Type} {M : Type → Type} {{Functor
M}} (s : S) (m : StateT S M A) : M A :=

View File

@ -7,4 +7,4 @@ builtin anoma-get
axiom anomaGet : {Value Key : Type} -> Key -> Value;
main (k1 : Nat) (k2 : List Nat) : List Nat :=
trace (anomaGet {Nat} k1) >>> anomaGet k2;
trace (anomaGet {Nat} k1) >-> anomaGet k2;

View File

@ -10,8 +10,8 @@ main : Nat :=
-- jam 0 == 2
trace (anomaEncode 0)
-- jam [1 2 0] == 84081
>>> trace (anomaEncode [1;2])
>-> trace (anomaEncode [1;2])
-- jam [1 2] == 4657
>>> trace (anomaEncode (1 , 2))
>-> trace (anomaEncode (1 , 2))
-- jam 1 == 12
>>> anomaEncode false;
>-> anomaEncode false;

View File

@ -10,8 +10,8 @@ main : Bool :=
-- cue 2 == 0
trace (anomaDecode {Nat} 2)
-- cue 84081 == [1 2 0]
>>> trace (anomaDecode {List Nat} 84081)
>-> trace (anomaDecode {List Nat} 84081)
-- cue 4657 == [1 2]
>>> trace (anomaDecode {Nat × Nat} 4657)
>-> trace (anomaDecode {Pair Nat Nat} 4657)
-- cue 12 == 1
>>> anomaDecode {Bool} 12;
>-> anomaDecode {Bool} 12;

View File

@ -7,7 +7,7 @@ iterate : {A : Type} → (A → A) → Nat → A → A
-- clauses with differing number of patterns not yet supported
-- iterate f zero x := x;
| f zero := id
| f (suc n) := f iterate f n;
| f (suc n) := f << iterate f n;
plus : Nat → Nat → Nat := iterate suc;

View File

@ -3,7 +3,7 @@ module test032;
import Stdlib.Prelude open;
split : {A : Type} → Nat → List A → List A × List A
split : {A : Type} → Nat → List A → Pair (List A) (List A)
| zero xs := nil, xs
| (suc n) nil := nil, nil
| (suc n) (x :: xs) :=
@ -46,7 +46,7 @@ gen2 : List (List Nat) → Nat → Nat → List (List Nat)
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (x :: xs) :=
printNat x >> printString " :: " >> printListNatLn xs;
printNat x >>> printString " :: " >>> printListNatLn xs;
sum : List Nat → Nat
| nil := 0

View File

@ -9,19 +9,19 @@ f : (Nat → Nat) → Nat
f' : Nat → Nat
| x := f ((+) x);
g : (Nat → Nat × Nat) → Nat × Nat
g : (Nat → Pair Nat Nat) → Pair Nat Nat
| f := f 2;
g' : Nat → Nat × Nat
g' : Nat → Pair Nat Nat
| x := g ((,) x);
f1' : Nat → Nat → Nat
| x y := f ((+) (div x y));
g1' : Nat → Nat → Nat × Nat
g1' : Nat → Nat → Pair Nat Nat
| x y := g ((,) (div x y));
h : (Nat → Nat → Nat × Nat) → Nat × Nat
h : (Nat → Nat → Pair Nat Nat) → Pair Nat Nat
| f := f 1 2;
main : Nat :=

View File

@ -44,7 +44,7 @@ h : Nat -> Nat
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (x :: xs) :=
printNat x >> printString " :: " >> printListNatLn xs;
printNat x >>> printString " :: " >>> printListNatLn xs;
main : Nat :=
head 0 (sum2 (lgen 5))

View File

@ -9,12 +9,12 @@ expand : {A : Type} → A → Nat → A
f : Nat → Nat := suc;
g : Nat → Nat → Nat
| z := f flip sub z;
| z := f << flip sub z;
g' : Nat → Nat → Nat
| z := f λ {x := sub x z};
| z := f << λ {x := sub x z};
h : Nat → Nat := f g 3;
h : Nat → Nat := f << g 3;
j : Nat → Nat → Nat := g';

View File

@ -36,12 +36,12 @@ myfor2
syntax iterator myzip2 {init := 2; range := 2};
myzip2
: {A A' B C : Type}
→ (A → A' → B → C → A × A')
→ (A → A' → B → C → Pair A A')
→ A
→ A'
→ List B
→ List C
A × A'
Pair A A'
| f a b xs ys :=
myfor (acc, acc' := a, b) (x, y in zip xs ys)
f acc acc' x y;

View File

@ -10,7 +10,7 @@ type Triple (A B C : Type) :=
thd : C
};
type Pair (A B : Type) :=
type Pair' (A B : Type) :=
mkPair {
fst : A;
snd : B
@ -19,7 +19,7 @@ type Pair (A B : Type) :=
sum : Triple Nat Nat Nat → Nat
| mkTriple@{fst; snd; thd} := fst + snd + thd;
mf : Pair (Pair Bool (List Nat)) (List Nat) → Bool
mf : Pair' (Pair' Bool (List Nat)) (List Nat) → Bool
| mkPair@{fst := mkPair@{fst; snd := nil};
snd := zero :: _} := fst
| x := case x of {_ := false};
@ -34,7 +34,7 @@ main : Nat :=
};
f : Triple Nat Nat Nat -> Triple Nat Nat Nat :=
(@Triple{fst := fst * 10});
in sum $ if
in sum <| if
(mf
mkPair@{
fst := mkPair true nil;

View File

@ -3,7 +3,7 @@ module test069;
import Stdlib.Data.Nat open hiding {Ord; mkOrd};
import Stdlib.Data.Nat.Ord as Ord;
import Stdlib.Data.Product as Ord;
import Stdlib.Data.Pair as Ord;
import Stdlib.Data.Bool.Base open;
import Stdlib.Trait.Ord open using {Ordering; LT; EQ; GT; isLT; isGT};

View File

@ -3,7 +3,7 @@ module test071;
import Stdlib.Data.Nat open hiding {Ord; mkOrd};
import Stdlib.Data.Nat.Ord as Ord;
import Stdlib.Data.Product as Ord;
import Stdlib.Data.Pair as Ord;
import Stdlib.Data.Bool.Base open;
import Stdlib.Trait.Ord open using {Ordering; LT; EQ; GT; isLT; isGT};

View File

@ -16,6 +16,6 @@ type Monad (f : Type -> Type) :=
open Monad public;
syntax operator >> bind;
>> {M : Type → Type} {A B : Type} {{Monad M}} (x : M
syntax operator >>> bind;
>>> {M : Type → Type} {A B : Type} {{Monad M}} (x : M
A) (y : M B) : M B := x >>= λ {_ := y};

View File

@ -10,7 +10,7 @@ instance
Reader-Functor {R : Type} : Functor (Reader R) :=
mkFunctor@{
<$> {A B : Type} (f : A -> B) : Reader R A -> Reader R B
| (mkReader ra) := mkReader (f ra)
| (mkReader ra) := mkReader (f << ra)
};
instance

View File

@ -52,13 +52,13 @@ ReaderT-MonadReader {S : Type} {M : Type → Type} {{Monad M}}
monad := ReaderT-Monad;
ask : ReaderT S M S := mkReaderT λ {s := MMonad.return s};
reader {A : Type} (f : S → A) : ReaderT S M A :=
mkReaderT (MMonad.return f)
mkReaderT (MMonad.return << f)
};
import MonadState open;
import StateT open;
import Identity open;
import Stdlib.Data.Product open;
import Stdlib.Data.Pair open;
liftReaderT {R A : Type} {M : Type → Type} (m : M A)
: ReaderT R M A := mkReaderT (const m);
@ -76,7 +76,7 @@ askNat {M : Type → Type} {{Monad M}} : ReaderT Nat M Nat :=
monadic : ReaderT Nat (StateT Nat Identity) Nat :=
askNat
>>= λ {n :=
liftReaderT (modify λ {m := m * n}) >> liftReaderT get};
liftReaderT (modify λ {m := m * n}) >>> liftReaderT get};
main : Nat :=
runIdentity (evalState 2 (runReader 5 monadic));
@ -87,6 +87,6 @@ main : Nat :=
-- → Type} {{mreader : MonadReader R M}} : MonadReader R (StateT S M) :=
-- mkMonadReader@{
-- monad := StateT-Monad@{mon := MonadReader.monad {{mreader}}};
-- reader {A : Type} : (R → A) → StateT S M A := liftStateT MonadReader.reader;
-- reader {A : Type} : (R → A) → StateT S M A := liftStateT << MonadReader.reader;
-- ask : StateT S M R := liftStateT MonadReader.ask;
-- };

View File

@ -2,7 +2,7 @@ module State;
import Monad open;
import Functor open;
import Stdlib.Data.Product open;
import Stdlib.Data.Pair open;
type State (S A : Type) := mkState {runState : S -> A × S};

View File

@ -4,15 +4,15 @@ import Monad open;
import Monad open using {module Monad as MMonad};
import Functor open;
import Functor open using {module Functor as MFunctor};
import Stdlib.Data.Product open;
import Stdlib.Data.Pair open;
type StateT (S : Type) (M : Type → Type) (A : Type) :=
mkStateT {runStateT : S → M (A × S)};
mkStateT {runStateT : S → M (Pair A S)};
runState {S A : Type} {M : Type → Type} (s : S) (m : StateT
S
M
A) : M (A × S) := StateT.runStateT m s;
A) : M (Pair A S) := StateT.runStateT m s;
evalState {S A : Type} {M : Type → Type} {{Functor
M}} (s : S) (m : StateT S M A) : M A :=

View File

@ -23,13 +23,13 @@ type ComplianceResult :=
y : Field
};
count : List (Field × Bool) -> Field
count : List (Pair Field Bool) -> Field
| [] := 0
| ((h, b) :: t) := if b (h + count t) (count t);
main
(input : Resource)
(path : List (Field × Bool))
(path : List (Pair Field Bool))
: ComplianceResult :=
mkResult@{
cnt := count path;
@ -44,7 +44,7 @@ main
{-
main
(input : Resource)
(path : List (Field × Bool))
(path : List (Pair Field Bool))
: Field :=
count path;
-}

View File

@ -13,7 +13,7 @@ import Stdlib.Prelude open;
main : IO :=
printNatLn (mod 3 2)
>> printNatLn (div 18 4)
>> printNatLn (mod 18 4)
>> printNatLn (div 16 4)
>> printNatLn (mod 16 4);
>>> printNatLn (div 18 4)
>>> printNatLn (mod 18 4)
>>> printNatLn (div 16 4)
>>> printNatLn (mod 16 4);

View File

@ -5,8 +5,8 @@ import Stdlib.Prelude open;
main : IO :=
printNat 1
>> printNat 2
>> printNat 3
>> printNat 4
>> printNat 5
>> printString "\n";
>>> printNat 2
>>> printNat 3
>>> printNat 4
>>> printNat 5
>>> printString "\n";

View File

@ -9,5 +9,5 @@ loop : Nat := loop;
main : IO :=
printNatLn
(if (3 > 0) 1 loop + if (2 < 1) loop (if (7 >= 8) loop 1))
>> printBoolLn (2 > 0 || loop == 0)
>> printBoolLn (2 < 0 && loop == 0);
>>> printBoolLn (2 > 0 || loop == 0)
>>> printBoolLn (2 < 0 && loop == 0);

View File

@ -18,17 +18,17 @@ lst : List Nat := 0 :: 1 :: nil;
printNatList : List Nat → IO
| nil := printString "nil"
| (h :: t) :=
printNat h >> printString " :: " >> printNatList t;
printNat h >>> printString " :: " >>> printNatList t;
printNatListLn (lst : List Nat) : IO :=
printNatList lst >> printString "\n";
printNatList lst >>> printString "\n";
main : IO :=
printBoolLn (null lst)
>> printBoolLn (null (nil {Nat}))
>> printNatLn (head 1 lst)
>> printNatListLn (tail lst)
>> printNatLn (head 0 (tail lst))
>> printNatListLn (map ((+) 1) lst)
>> printNatListLn (map' ((+) 1) lst)
>> printNatListLn (runPartial (λ{{{_}} := map'' ((+) 1) lst}));
>>> printBoolLn (null (nil {Nat}))
>>> printNatLn (head 1 lst)
>>> printNatListLn (tail lst)
>>> printNatLn (head 0 (tail lst))
>>> printNatListLn (map ((+) 1) lst)
>>> printNatListLn (map' ((+) 1) lst)
>>> printNatListLn (runPartial (λ{{{_}} := map'' ((+) 1) lst}));

View File

@ -17,6 +17,6 @@ fact : Nat → Nat := fact' 1;
main : IO :=
printNatLn (sum 10000)
>> printNatLn (fact 5)
>> printNatLn (fact 10)
>> printNatLn (fact 12);
>>> printNatLn (fact 5)
>>> printNatLn (fact 10)
>>> printNatLn (fact 12);

View File

@ -11,5 +11,5 @@ fib : Nat → Nat := fib' 0 1;
main : IO :=
printNatLn (fib 10)
>> printNatLn (fib 100)
>> printNatLn (fib 1000);
>>> printNatLn (fib 100)
>>> printNatLn (fib 1000);

View File

@ -20,19 +20,19 @@ gen : Nat → Tree
preorder : Tree → IO
| leaf := printNat 0
| (node1 c) := printNat 1 >> preorder c
| (node2 l r) := printNat 2 >> preorder l >> preorder r
| (node1 c) := printNat 1 >>> preorder c
| (node2 l r) := printNat 2 >>> preorder l >>> preorder r
| (node3 l m r) :=
printNat 3 >> preorder l >> preorder m >> preorder r;
printNat 3 >>> preorder l >>> preorder m >>> preorder r;
main : IO :=
preorder (gen 3)
>> printString "\n"
>> preorder (gen 4)
>> printString "\n"
>> preorder (gen 5)
>> printString "\n"
>> preorder (gen 6)
>> printString "\n"
>> preorder (gen 7)
>> printString "\n";
>>> printString "\n"
>>> preorder (gen 4)
>>> printString "\n"
>>> preorder (gen 5)
>>> printString "\n"
>>> preorder (gen 6)
>>> printString "\n"
>>> preorder (gen 7)
>>> printString "\n";

View File

@ -15,6 +15,6 @@ f : Nat → Nat → Nat
main : IO :=
printNatLn (f 5 6)
>> printNatLn (f 6 5)
>> printNatLn (f 10 5)
>> printNatLn (f 11 5);
>>> printNatLn (f 6 5)
>>> printNatLn (f 10 5)
>>> printNatLn (f 11 5);

View File

@ -23,13 +23,13 @@ vy : Nat := 7;
main : IO :=
printNatLn (func (div y x))
>> -- 17 div 5 + 4 = 7
>>> -- 17 div 5 + 4 = 7
printNatLn
(y + x * z)
>> -- 17
>>> -- 17
printNatLn
(vx + vy * (z + 1))
>> -- 37
>>> -- 37
f
(h g 2 3)
4;

View File

@ -21,18 +21,18 @@ h : Nat → Nat
main : IO :=
printNatLn (f 100 500)
>> -- 600
>>> -- 600
printNatLn
(f 5 0)
>> -- 25
>>> -- 25
printNatLn
(f 5 5)
>> -- 30
>>> -- 30
printNatLn
(h 10)
>> -- 45
>>> -- 45
printNatLn
(g 10 h)
>> -- 55
>>> -- 55
printNatLn
(g 3 (f 10));

View File

@ -15,11 +15,11 @@ subp : Nat → Nat → Nat
main : IO :=
printNatLn (f91 101)
>> printNatLn (f91 95)
>> printNatLn (f91 16)
>> printNatLn (f91 5)
>> printNatLn (subp 101 1)
>> printNatLn (subp 11 5)
>> printNatLn (subp 10 4)
>> printNatLn (subp 1000 600)
>> printNatLn (subp 10000 6000);
>>> printNatLn (f91 95)
>>> printNatLn (f91 16)
>>> printNatLn (f91 5)
>>> printNatLn (subp 101 1)
>>> printNatLn (subp 11 5)
>>> printNatLn (subp 10 4)
>>> printNatLn (subp 1000 600)
>>> printNatLn (subp 10000 6000);

View File

@ -15,5 +15,5 @@ power : Nat → Nat → Nat := power' 1;
main : IO :=
printNatLn (power 2 3)
>> printNatLn (power 3 7)
>> printNatLn (power 5 11);
>>> printNatLn (power 3 7)
>>> printNatLn (power 5 11);

View File

@ -16,13 +16,13 @@ sum' : Nat → Nat
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (h :: t) :=
printNat h >> printString " :: " >> printListNatLn t;
printNat h >>> printString " :: " >>> printListNatLn t;
main : IO :=
printListNatLn (gen 10)
>> printListNatLn (reverse (gen 10))
>> printListNatLn (filter ((<) 5) (gen 10))
>> printListNatLn (reverse (map (flip sub 1) (gen 10)))
>> printNatLn (sum 10000)
>> printNatLn (sum' 10000);
>>> printListNatLn (reverse (gen 10))
>>> printListNatLn (filter ((<) 5) (gen 10))
>>> printListNatLn (reverse (map (flip sub 1) (gen 10)))
>>> printNatLn (sum 10000)
>>> printNatLn (sum' 10000);

View File

@ -18,6 +18,6 @@ h : Nat → Nat
main : IO :=
printNatLn (f 5)
>> printNatLn (f 10)
>> printNatLn (f 20);
>>> printNatLn (f 10)
>>> printNatLn (f 20);

View File

@ -13,8 +13,8 @@ gcd : Nat → Nat → Nat
main : IO :=
printNatLn (gcd (3 * 7 * 2) (7 * 2 * 11))
>> printNatLn (gcd (3 * 7 * 2 * 11 * 5) (7 * 2 * 5))
>> printNatLn (gcd 3 7)
>> printNatLn (gcd 7 3)
>> printNatLn (gcd (11 * 7 * 3) (2 * 5 * 13));
>>> printNatLn (gcd (3 * 7 * 2 * 11 * 5) (7 * 2 * 5))
>>> printNatLn (gcd 3 7)
>>> printNatLn (gcd 7 3)
>>> printNatLn (gcd (11 * 7 * 3) (2 * 5 * 13));

View File

@ -52,7 +52,7 @@ f {{Partial}} : Nat → Queue Nat → List Nat
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (h :: t) :=
printNat h >> printString " :: " >> printListNatLn t;
printNat h >>> printString " :: " >>> printListNatLn t;
main : IO :=
printListNatLn (runPartial λ {{{_}} := f 100 empty});

View File

@ -9,17 +9,17 @@ czero : Num
| {_} f x := x;
csuc : Num → Num
| n {_} f := f n {_} f;
| n {_} f := f << n {_} f;
num : Nat → Num
| zero := czero
| (suc n) := csuc (num n);
add : Num → Num → Num
| n m {_} f := n {_} f m {_} f;
| n m {_} f := n {_} f << m {_} f;
mul : Num → Num → Num
| n m {_} := n {_} m {_};
| n m {_} := n {_} << m {_};
isZero : Num → Bool
| n := n {_} (const false) true;
@ -29,5 +29,5 @@ toNat : Num → Nat
main : IO :=
printNatLn (toNat (num 7))
>> printNatLn (toNat (add (num 7) (num 3)))
>> printNatLn (toNat (mul (num 7) (num 3)));
>>> printNatLn (toNat (add (num 7) (num 3)))
>>> printNatLn (toNat (mul (num 7) (num 3)));

View File

@ -43,6 +43,6 @@ primes : Unit → Stream := eratostenes (numbers 2);
main : IO :=
printNatLn (snth 10 primes)
>> printNatLn (snth 50 primes)
>> printNatLn (snth 100 primes)
>> printNatLn (snth 200 primes);
>>> printNatLn (snth 50 primes)
>>> printNatLn (snth 100 primes)
>>> printNatLn (snth 200 primes);

View File

@ -10,8 +10,8 @@ ack : Nat → Nat → Nat
main : IO :=
printNatLn (ack 0 7)
>> printNatLn (ack 1 7)
>> printNatLn (ack 1 13)
>> printNatLn (ack 2 7)
>> printNatLn (ack 2 13)
>> printNatLn (ack 3 7);
>>> printNatLn (ack 1 7)
>>> printNatLn (ack 1 13)
>>> printNatLn (ack 2 7)
>>> printNatLn (ack 2 13)
>>> printNatLn (ack 3 7);

View File

@ -7,7 +7,7 @@ iterate : {A : Type} → (A → A) → Nat → A → A
-- clauses with differing number of patterns not yet supported
-- iterate f zero x := x;
| f zero := id
| f (suc n) := f iterate f n;
| f (suc n) := f << iterate f n;
plus : Nat → Nat → Nat := iterate suc;
@ -22,7 +22,7 @@ ackermann : Nat → Nat → Nat
main : IO :=
printNatLn (plus 3 7)
>> printNatLn (mult 3 7)
>> printNatLn (exp 3 7)
>> printNatLn (ackermann 3 7);
>>> printNatLn (mult 3 7)
>>> printNatLn (exp 3 7)
>>> printNatLn (ackermann 3 7);

View File

@ -14,6 +14,6 @@ mklst2 : Nat → List (List Nat)
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (x :: xs) :=
printNat x >> printString " :: " >> printListNatLn xs;
printNat x >>> printString " :: " >>> printListNatLn xs;
main : IO := printListNatLn (flatten (mklst2 4));

View File

@ -3,7 +3,7 @@ module test032;
import Stdlib.Prelude open;
split : {A : Type} → Nat → List A → List A × List A
split : {A : Type} → Nat → List A → Pair (List A) (List A)
| zero xs := nil, xs
| (suc n) nil := nil, nil
| (suc n) (x :: xs) :=
@ -46,12 +46,12 @@ gen2 : List (List Nat) → Nat → Nat → List (List Nat)
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (x :: xs) :=
printNat x >> printString " :: " >> printListNatLn xs;
printNat x >>> printString " :: " >>> printListNatLn xs;
main : IO :=
printListNatLn
(take 10 (uniq (sort (flatten (gen2 nil 6 40)))))
>> printListNatLn
>>> printListNatLn
(take 10 (uniq (sort (flatten (gen2 nil 9 80)))))
>> printListNatLn
>>> printListNatLn
(take 10 (uniq (sort (flatten (gen2 nil 6 80)))));

View File

@ -9,33 +9,32 @@ f : (Nat → Nat) → Nat
f' : Nat → Nat
| x := f ((+) x);
g : (Nat → Nat × Nat) → Nat × Nat
g : (Nat → Pair Nat Nat) → Pair Nat Nat
| f := f 2;
g' : Nat → Nat × Nat
g' : Nat → Pair Nat Nat
| x := g ((,) x);
f1' : Nat → Nat → Nat
| x y := f ((+) (div x y));
g1' : Nat → Nat → Nat × Nat
g1' : Nat → Nat → Pair Nat Nat
| x y := g ((,) (div x y));
h : (Nat → Nat → Nat × Nat) → Nat × Nat
h : (Nat → Nat → Pair Nat Nat) → Pair Nat Nat
| f := f 1 2;
printPairNatLn : Nat × Nat → IO
printPairNatLn : Pair Nat Nat → IO
| (x, y) :=
printString "("
>> printNat x
>> printString ", "
>> printNat y
>> printStringLn ")";
>>> printNat x
>>> printString ", "
>>> printNat y
>>> printStringLn ")";
main : IO :=
printNatLn (f' 7)
>> printPairNatLn (g' 7)
>> printNatLn (f1' 7 2)
>> printPairNatLn (g1' 7 2)
>> printPairNatLn (h (,));
>>> printPairNatLn (g' 7)
>>> printNatLn (f1' 7 2)
>>> printPairNatLn (g1' 7 2)
>>> printPairNatLn (h (,));

View File

@ -21,8 +21,8 @@ mutrec : IO :=
terminating
h (x : Nat) : Nat := if (x < 1) 1 (x * f (sub x 1));
in printNatLn (f 5)
>> printNatLn (f 10)
>> printNatLn (g 5)
>> printNatLn (h 5);
>>> printNatLn (f 10)
>>> printNatLn (g 5)
>>> printNatLn (h 5);
main : IO := printNatLn (sum 10000) >> mutrec;
main : IO := printNatLn (sum 10000) >>> mutrec;

View File

@ -43,16 +43,16 @@ h : Nat -> Nat
printListNatLn : List Nat → IO
| nil := printStringLn "nil"
| (x :: xs) :=
printNat x >> printString " :: " >> printListNatLn xs;
printNat x >>> printString " :: " >>> printListNatLn xs;
main : IO :=
printListNatLn (sum2 (lgen 5))
>> printNatLn (f (gen 10))
>> printNatLn (f (gen 15))
>> printNatLn (f (gen 16))
>> printNatLn (f (gen 17))
>> printNatLn (f (gen 18))
>> printNatLn (f (gen 20))
>> printNatLn (h 5)
>> printNatLn (h 3);
>>> printNatLn (f (gen 10))
>>> printNatLn (f (gen 15))
>>> printNatLn (f (gen 16))
>>> printNatLn (f (gen 17))
>>> printNatLn (f (gen 18))
>>> printNatLn (f (gen 20))
>>> printNatLn (h 5)
>>> printNatLn (h 3);

View File

@ -9,12 +9,12 @@ expand : {A : Type} → A → Nat → A
f : Nat → Nat := suc;
g : Nat → Nat → Nat
| z := f flip sub z;
| z := f << flip sub z;
g' : Nat → Nat → Nat
| z := f λ {x := sub x z};
| z := f << λ {x := sub x z};
h : Nat → Nat := f g 3;
h : Nat → Nat := f << g 3;
j : Nat → Nat → Nat := g';

View File

@ -15,4 +15,4 @@ main : IO :=
| (suc n) := not (odd n);
plusOne (n : Ty) : Ty := n + 1;
in printBoolLn (odd (plusOne 13))
>> printBoolLn (even (plusOne 12));
>>> printBoolLn (even (plusOne 12));

View File

@ -9,39 +9,39 @@ f : Int -> Nat
main : IO :=
printStringLn (intToString 1)
>> printStringLn (intToString -1)
>> printIntLn (ofNat 1)
>> printIntLn (negSuc 0)
>> printIntLn (ofNat (suc zero))
>> printIntLn (negSuc zero)
>> printStringLn (natToString (f 1))
>> printNatLn (f -1)
>> printNatLn (f (ofNat (suc zero)))
>> printNatLn (f (negSuc (suc zero)))
>> printBoolLn (-1 == -2)
>> printBoolLn (-1 == -1)
>> printBoolLn (1 == 1)
>> printBoolLn (-1 == 1)
>> printIntLn (-1 + 1)
>> printIntLn (negNat (suc zero))
>> printIntLn
>>> printStringLn (intToString -1)
>>> printIntLn (ofNat 1)
>>> printIntLn (negSuc 0)
>>> printIntLn (ofNat (suc zero))
>>> printIntLn (negSuc zero)
>>> printStringLn (natToString (f 1))
>>> printNatLn (f -1)
>>> printNatLn (f (ofNat (suc zero)))
>>> printNatLn (f (negSuc (suc zero)))
>>> printBoolLn (-1 == -2)
>>> printBoolLn (-1 == -1)
>>> printBoolLn (1 == 1)
>>> printBoolLn (-1 == 1)
>>> printIntLn (-1 + 1)
>>> printIntLn (negNat (suc zero))
>>> printIntLn
(let
g : Nat -> Int := negNat;
in g (suc zero))
>> printIntLn (neg -1)
>> printIntLn
>>> printIntLn (neg -1)
>>> printIntLn
(let
g : Int -> Int := neg;
in g -1)
>> printIntLn (-2 * 2)
>> printIntLn (div 4 -2)
>> printIntLn (2 - 2)
>> printBoolLn (nonNeg 0)
>> printBoolLn (nonNeg -1)
>> printIntLn (mod -5 -2)
>> printBoolLn (0 < 0)
>> printBoolLn (0 <= 0)
>> printBoolLn (0 < 1)
>> printBoolLn (1 <= 0)
>> printIntLn (mod 5 -3)
>> printIntLn (div 5 -3);
>>> printIntLn (-2 * 2)
>>> printIntLn (div 4 -2)
>>> printIntLn (2 - 2)
>>> printBoolLn (nonNeg 0)
>>> printBoolLn (nonNeg -1)
>>> printIntLn (mod -5 -2)
>>> printBoolLn (0 < 0)
>>> printBoolLn (0 <= 0)
>>> printBoolLn (0 < 1)
>>> printBoolLn (1 <= 0)
>>> printIntLn (mod 5 -3)
>>> printIntLn (div 5 -3);

View File

@ -1,4 +1,4 @@
-- local recursive function using IO >>
-- local recursive function using IO >>>
module test051;
import Stdlib.Prelude open;
@ -7,5 +7,5 @@ main : IO :=
let
f : Nat -> IO
| zero := printStringLn ""
| (suc n) := printString "*" >> f n;
| (suc n) := printString "*" >>> f n;
in f 3;

View File

@ -36,12 +36,12 @@ myfor2
syntax iterator myzip2 {init := 2; range := 2};
myzip2
: {A A' B C : Type}
→ (A → A' → B → C → A × A')
→ (A → A' → B → C → Pair A A')
→ A
→ A'
→ List B
→ List C
A × A'
Pair A A'
| f a b xs ys :=
myfor (acc, acc' := a, b) (x, y in zip xs ys)
f acc acc' x y;

View File

@ -3,9 +3,9 @@ module test055;
import Stdlib.Prelude open;
type Pair :=
| pair : Nat -> Nat -> Pair;
type Pair' :=
| pair : Nat -> Nat -> Pair';
main : List (Pair × Nat) × List Pair :=
main : Pair (List (Pair Pair' Nat)) (List Pair') :=
(pair 1 2, 3) :: (pair 2 3, 4) :: nil
, pair 1 2 :: pair 2 3 :: nil;

View File

@ -10,13 +10,13 @@ type Triple (A B C : Type) :=
thd : C
};
type Pair (A B : Type) :=
type Pair' (A B : Type) :=
mkPair {
fst : A;
snd : B
};
mf : Pair (Pair Bool (List Nat)) (List Nat) → Bool
mf : Pair' (Pair' Bool (List Nat)) (List Nat) → Bool
| mkPair@{fst := mkPair@{fst; snd := nil};
snd := zero :: _} := fst
| x := case x of _ := false;

View File

@ -66,7 +66,7 @@ showBoolFunI : Show (Bool → Bool) := mkShow@{
};
instance
showPairI {A B} {{Show A}} {{Show' B}} : Show' (A × B) :=
showPairI {A B} {{Show A}} {{Show' B}} : Show' (Pair A B) :=
mkShow λ {(x, y) := Show.show x ++str ", " ++str Show.show y};
trait
@ -79,19 +79,19 @@ instance
tFunI {A} {{T A}} : T (A -> A) := mkT \ { a := a };
main : IO :=
printStringLn (Show.show true) >>
printStringLn (f false) >>
printStringLn (Show.show 3) >>
printStringLn (Show.show (g {Nat})) >>
printStringLn (Show.show [true; false]) >>
printStringLn (Show.show [1; 2; 3]) >>
printStringLn (f' [1; 2]) >>
printStringLn (f'' [true; false]) >>
printStringLn (f'3 [just true; nothing; just false]) >>
printStringLn (f'4 [just [1]; nothing; just [2; 3]]) >>
printStringLn (f'3 "abba") >>
printStringLn (f'3 {{M := mkShow (λ{x := x ++str "!"})}} "abba") >>
printStringLn (f5 "abba" 3) >>
printStringLn (Show.show {{_}} ["a"; "b"; "c"; "d"]) >>
printStringLn (Show.show (λ{x := not x})) >>
printStringLn (Show.show true) >>>
printStringLn (f false) >>>
printStringLn (Show.show 3) >>>
printStringLn (Show.show (g {Nat})) >>>
printStringLn (Show.show [true; false]) >>>
printStringLn (Show.show [1; 2; 3]) >>>
printStringLn (f' [1; 2]) >>>
printStringLn (f'' [true; false]) >>>
printStringLn (f'3 [just true; nothing; just false]) >>>
printStringLn (f'4 [just [1]; nothing; just [2; 3]]) >>>
printStringLn (f'3 "abba") >>>
printStringLn (f'3 {{M := mkShow (λ{x := x ++str "!"})}} "abba") >>>
printStringLn (f5 "abba" 3) >>>
printStringLn (Show.show {{_}} ["a"; "b"; "c"; "d"]) >>>
printStringLn (Show.show (λ{x := not x})) >>>
printStringLn (Show.show (3, [1; 2 + T.a 0]));

View File

@ -77,10 +77,10 @@ h {A} {{U2 A}} : A -> A := f;
main : IO :=
printStringLn (T1.pp "a")
>> printStringLn (T2.pp "b")
>> printStringLn (T3.pp "c")
>> printStringLn (T4.pp "d")
>> printStringLn (U.pp "e")
>> printStringLn (f "f")
>> printStringLn (g {{mkU1 id}} "g")
>> printStringLn (h "h");
>>> printStringLn (T2.pp "b")
>>> printStringLn (T3.pp "c")
>>> printStringLn (T4.pp "d")
>>> printStringLn (U.pp "e")
>>> printStringLn (f "f")
>>> printStringLn (g {{mkU1 id}} "g")
>>> printStringLn (h "h");

View File

@ -3,7 +3,7 @@ module test069;
import Stdlib.Data.Nat open hiding {Ord; mkOrd};
import Stdlib.Data.Nat.Ord as Ord;
import Stdlib.Data.Product as Ord;
import Stdlib.Data.Pair as Ord;
import Stdlib.Data.Bool.Base open;
import Stdlib.Trait.Ord open using {Ordering; LT; EQ; GT; isLT; isGT};

View File

@ -3,7 +3,7 @@ module test071;
import Stdlib.Data.Nat open hiding {Ord; mkOrd};
import Stdlib.Data.Nat.Ord as Ord;
import Stdlib.Data.Product as Ord;
import Stdlib.Data.Pair as Ord;
import Stdlib.Data.Bool.Base open;
import Stdlib.Trait.Ord open using {Ordering; LT; EQ; GT; isLT; isGT};

View File

@ -16,6 +16,6 @@ type Monad (f : Type -> Type) :=
open Monad public;
syntax operator >> bind;
>> {M : Type → Type} {A B : Type} {{Monad M}} (x : M
syntax operator >>> bind;
>>> {M : Type → Type} {A B : Type} {{Monad M}} (x : M
A) (y : M B) : M B := x >>= λ {_ := y};

Some files were not shown because too many files have changed in this diff Show More