В последнее время я переписал многие стандартные библиотечные функции OCaml, чтобы быть рекурсивными. Учитывая, что это влекло за собой прямое преобразование CPS, я оставляю недоумение, почему версии по умолчанию не написаны таким образом.
В качестве примера, в стандартной библиотеке карта определяется как:
let rec map f = function
[] -> []
| a::l -> let r = f a in r :: map f l
Я переписал его как:
let map f l =
let rec aux l k = match l with
[] -> k []
| a::l -> aux l (fun rest -> k (f a :: rest))
in aux l (fun x -> x)