sig
type 'a t = 'a list
val length : 'a Js_list.t -> int
val cons : 'a -> 'a Js_list.t -> 'a Js_list.t
val isEmpty : 'a Js_list.t -> bool
val hd : 'a Js_list.t -> 'a option
val tl : 'a Js_list.t -> 'a Js_list.t option
val nth : 'a Js_list.t -> int -> 'a option
val revAppend : 'a Js_list.t -> 'a Js_list.t -> 'a Js_list.t
val rev : 'a Js_list.t -> 'a Js_list.t
val mapRev :
([ `Arity_1 of 'a ], 'b) Js.Internal.fn -> 'a Js_list.t -> 'b Js_list.t
val map :
([ `Arity_1 of 'a ], 'b) Js.Internal.fn -> 'a Js_list.t -> 'b Js_list.t
val iter :
([ `Arity_1 of 'a ], unit) Js.Internal.fn -> 'a Js_list.t -> unit
val iteri :
([ `Arity_2 of int * 'a ], unit) Js.Internal.fn -> 'a Js_list.t -> unit
val foldLeft :
([ `Arity_2 of 'a * 'b ], 'a) Js.Internal.fn -> 'a -> 'b list -> 'a
val foldRight :
([ `Arity_2 of 'a * 'b ], 'b) Js.Internal.fn -> 'a list -> 'b -> 'b
val flatten : 'a Js_list.t Js_list.t -> 'a Js_list.t
val filter :
([ `Arity_1 of 'a ], bool) Js.Internal.fn -> 'a Js_list.t -> 'a Js_list.t
val filterMap :
([ `Arity_1 of 'a ], 'b option) Js.Internal.fn ->
'a Js_list.t -> 'b Js_list.t
val countBy : ([ `Arity_1 of 'a ], bool) Js.Internal.fn -> 'a list -> int
val init : int -> ([ `Arity_1 of int ], 'a) Js.Internal.fn -> 'a Js_list.t
val equal :
([ `Arity_2 of 'a * 'a ], bool) Js.Internal.fn ->
'a list -> 'a list -> bool
end