Browse thread
Bug in ocamlc or in ocamlrun.
[
Home
]
[ Index:
by date
|
by threads
]
[ Message by date: previous | next ] [ Message in thread: previous | next ] [ Thread: previous | next ]
[ Message by date: previous | next ] [ Message in thread: previous | next ] [ Thread: previous | next ]
| Date: | -- (:) |
| From: | Marc Lasson <titmarc@f...> |
| Subject: | Bug in ocamlc or in ocamlrun. |
Hello,
When i compile the following program with ocamlc i get a segmentation fault.
Is it a bug in the ocaml system ? I did not succeed to isolate it.
----------------------
module LL (R : sig
type t
val add : t -> t -> t
end) =
struct
type t = R.t list
let add = List.map2 (R.add)
end
module rec M : sig
type t = P of int | L of LS.t
val add : t -> t -> t
val to_string : t -> string
end = struct
type param = ()
type t = P of int
| L of LS.t
let add a b = match a, b with
P a', P b' -> P (a'+b')
| L a', L b' -> L (LS.add a' b')
| _ -> failwith "incompatible"
let rec to_string = function
P i -> string_of_int i
| L l -> List.fold_left (fun r x -> r^" "^(to_string x)) "" l
end
and LS : sig type t = M.t list val add : t -> t -> t end = LL(M)
open M
let p = L [P 1; P 2]
let q = add p p
let () =
print_endline (to_string p);
print_endline (to_string q)
----------------------
If i replace the function LL.add by
let rec add a b = match a, b with
[], [] -> []
| x::a', y::b' -> (R.add x y)::(add a' b')
| _ -> failwith "add"
the segmentation fault magically disappear.
Hope that helps,
--
Marc Lasson.