Skip to content

Latest commit

 

History

History
24 lines (18 loc) · 514 Bytes

README.md

File metadata and controls

24 lines (18 loc) · 514 Bytes

recursion

Build Status

Example

Sum a list of integers using a catamorphism:

staload "SATS/recursive.sats"

#include "DATS/recursive.dats"
#include "DATS/recursive_list0.dats"

fun sum(is : list0(int)) : int =
  let
    fn go(i : list0f(int, int)) : int =
      case+ i of
        | list0_consf (x, xs) => x + xs
        | list0_nilf() => 0
  in
    cata(lam x0 =<cloref1> go(x0), is)
  end