sig
  module SMap :
    sig
      type key = string
      type +'a t
      val empty : 'a t
      val is_empty : 'a t -> bool
      val mem : key -> 'a t -> bool
      val add : key -> '-> 'a t -> 'a t
      val singleton : key -> '-> 'a t
      val remove : key -> 'a t -> 'a t
      val merge :
        (key -> 'a option -> 'b option -> 'c option) -> 'a t -> 'b t -> 'c t
      val compare : ('-> '-> int) -> 'a t -> 'a t -> int
      val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
      val iter : (key -> '-> unit) -> 'a t -> unit
      val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b
      val for_all : (key -> '-> bool) -> 'a t -> bool
      val exists : (key -> '-> bool) -> 'a t -> bool
      val filter : (key -> '-> bool) -> 'a t -> 'a t
      val partition : (key -> '-> bool) -> 'a t -> 'a t * 'a t
      val cardinal : 'a t -> int
      val bindings : 'a t -> (key * 'a) list
      val min_binding : 'a t -> key * 'a
      val max_binding : 'a t -> key * 'a
      val choose : 'a t -> key * 'a
      val split : key -> 'a t -> 'a t * 'a option * 'a t
      val find : key -> 'a t -> 'a
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
    end
  exception OptionalArgument of (string * string)
  exception ParseError of (int * int * string)
  val string_of_ParseError : int * int * string -> string
  val from_channel :
    Pervasives.in_channel -> (string * string Calc.t list) Lilis.lsystem list
  val from_string :
    string -> (string * string Calc.t list) Lilis.lsystem list
  val lsystem_from_string :
    string -> (string * string Calc.t list) Lilis.lsystem
  val to_string : (string * string Calc.t list) Lilis.lsystem -> string
  val fprint :
    Format.formatter -> (string * string Calc.t list) Lilis.lsystem -> unit
  val fprint_rule :
    Format.formatter -> (string * string Calc.t list) Lilis.rule -> unit
  exception ArityError of (string * int * int)
  exception VarDefError of (string * string)
  exception TokenDefError of string
  val check_stream : int LisUtils.SMap.t -> (string * 'a list) list -> unit
  val check_rule :
    int LisUtils.SMap.t ->
    ?arit_env:Calc.Env.t -> (string * string Calc.t list) Lilis.rule -> unit
  val replace_in_post_rules :
    (string * ('a * int)) list ->
    (string * 'b list) Lilis.lsystem -> ('a * 'b list) Lilis.lsystem
end