Blame camlp4/examples/test_macros.ml
|
Packit |
1f8b6b |
(****************************************************************************)
|
|
Packit |
1f8b6b |
(* *)
|
|
Packit |
1f8b6b |
(* OCaml *)
|
|
Packit |
1f8b6b |
(* *)
|
|
Packit |
1f8b6b |
(* INRIA Rocquencourt *)
|
|
Packit |
1f8b6b |
(* *)
|
|
Packit |
1f8b6b |
(* Copyright 2007 Institut National de Recherche en Informatique et *)
|
|
Packit |
1f8b6b |
(* en Automatique. All rights reserved. This file is distributed under *)
|
|
Packit |
1f8b6b |
(* the terms of the GNU Library General Public License, with the special *)
|
|
Packit |
1f8b6b |
(* exception on linking described in LICENSE at the top of the Camlp4 *)
|
|
Packit |
1f8b6b |
(* source tree. *)
|
|
Packit |
1f8b6b |
(* *)
|
|
Packit |
1f8b6b |
(****************************************************************************)
|
|
Packit |
1f8b6b |
|
|
Packit |
1f8b6b |
(* DEFINE F(x, y, z) = x + y * z;; *)
|
|
Packit |
1f8b6b |
(* F(F(1, 2, 3), 4, 5);; *)
|
|
Packit |
1f8b6b |
|
|
Packit |
1f8b6b |
(* !+ (1, 2, 3, 4);; *)
|
|
Packit |
1f8b6b |
|
|
Packit |
1f8b6b |
(* foldl(( + ), 1, 2, 3, 4);; *)
|
|
Packit |
1f8b6b |
(* foldr(cons, 1, 2, 3, []);; *)
|
|
Packit |
1f8b6b |
|
|
Packit |
1f8b6b |
let cons x xs = x :: xs;;
|
|
Packit |
1f8b6b |
|
|
Packit |
1f8b6b |
def_foldl ( !+ ) ( + );;
|
|
Packit |
1f8b6b |
def_foldr ( !:: ) cons;;
|
|
Packit |
1f8b6b |
|
|
Packit |
1f8b6b |
!+ (1, 2, 3, 4);;
|
|
Packit |
1f8b6b |
!:: (1, 2, 3, []);;
|