summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorChenggang Duan <cgduan@live.com>2015-02-12 16:54:26 +0800
committerChenggang Duan <cgduan@live.com>2015-02-12 16:54:26 +0800
commit8c70acc9fb102e5884fb9e05c79e07015c3e4188 (patch)
treea1ced8e793dc3c25014aa697e16f881775f06fa8
parent6edf12c4d723bdb4d4a04192f8786ff19459161f (diff)
[ocaml/en] Change the example of mutually recursive functions
Change the example to a meaningful and self-contained example of mutually recursive functions.
-rw-r--r--ocaml.html.markdown15
1 files changed, 10 insertions, 5 deletions
diff --git a/ocaml.html.markdown b/ocaml.html.markdown
index f9db7080..b30d920b 100644
--- a/ocaml.html.markdown
+++ b/ocaml.html.markdown
@@ -144,11 +144,16 @@ x + y ;;
(* Alternatively you can use "let ... and ... in" construct.
This is especially useful for mutually recursive functions,
with ordinary "let .. in" the compiler will complain about
- unbound values.
- It's hard to come up with a meaningful but self-contained
- example of mutually recursive functions, but that syntax
- works for non-recursive definitions too. *)
-let a = 3 and b = 4 in a * b ;;
+ unbound values. *)
+let rec
+ is_even = function
+ | 0 -> true
+ | n -> is_odd (n-1)
+and
+ is_odd = function
+ | 0 -> false
+ | n -> is_even (n-1)
+;;
(* Anonymous functions use the following syntax: *)
let my_lambda = fun x -> x * x ;;