我尝试通过实现这段代码来使用一流的模块:
module Component =
struct
type t_data = ..
module type S =
sig
type t
val create : t -> t_data
end
module Make (C: sig type t end) =
struct
type t = C.t
type t_data += T of C.t
let create data = T data
end
end
let create m data =
let module M = (val m : Component.S) in M.create data
(* The type constructor M.t would escape its scope *)
我也会尝试这种替代方法,但我不知道如何在模块 S 中添加扩展类型 t_data :
let create' m data =
let module M = (val m : Component.S) in M.T data
(* Unbound constructor M.T *)
我正在使用bucklescript,谢谢!