sig
  type 'a t
  type 'a stored
  val singleton : '-> 'Lilis.S.t
  val map : ('-> 'b) -> 'Lilis.S.t -> 'Lilis.S.t
  val expand : ('-> 'Lilis.S.t) -> 'Lilis.S.t -> 'Lilis.S.t
  val iter : ('-> unit) -> 'Lilis.S.t -> unit
  val fold : ('-> '-> 'b) -> '-> 'Lilis.S.t -> 'b
  val of_list : 'a list -> 'Lilis.S.stored
  val to_list : 'Lilis.S.t -> 'a list
  val empty : 'Lilis.S.stored
  val store : 'Lilis.S.t -> 'Lilis.S.stored
  val gennew : 'Lilis.S.stored -> 'Lilis.S.t
end