sig
  val last : 'a list -> 'a
  val cons_option : 'a option -> 'a list -> 'a list
  val exists_uniq : ('-> bool) -> 'a list -> bool
  val find_option : ('-> bool) -> 'a list -> 'a option
  val rev_map_append : ('-> 'b) -> 'a list -> 'b list -> 'b list
  val map_flatten : ('-> 'b list) -> 'a list -> 'b list
  val fold_right_map : ('-> '-> 'c * 'b) -> 'a list -> '-> 'c list * 'b
  val fold_left2 : ('-> '-> '-> 'a) -> '-> 'b list -> 'c list -> 'a
  val mapi : (int -> '-> 'b) -> 'a list -> 'b list
  val map_option : ('-> 'b option) -> 'a list -> 'b list
  val random : Random.State.t -> 'a list -> 'a
  val merge_uniq : ('-> '-> int) -> 'a list -> 'a list -> 'a list
  val smart_filter : ('-> bool) -> 'a list -> 'a list
  val smart_map : ('-> 'a) -> 'a list -> 'a list
  val remove_suffix_after_last_occurrence :
    ('-> bool) -> 'a list -> 'a list
  val remove_consecutive_double : 'a list -> 'a list
  module Infix : sig val ( $$ ) : 'a option -> 'a list -> 'a list end
end