X-Git-Url: https://git.hcoop.net/hcoop/domtool2.git/blobdiff_plain/e0b0abd209a1ecbd9266cfcf8735af171f96869b..06bd821502f57dcb4ef89295b221fc2b9a4f1ae3:/src/env.sig diff --git a/src/env.sig b/src/env.sig index 477af94..0a50620 100644 --- a/src/env.sig +++ b/src/env.sig @@ -38,6 +38,10 @@ signature ENV = sig val registerPost : (unit -> unit) -> unit val post : unit -> unit + (* ...and before type-checking *) + val registerPreTycheck : (unit -> unit) -> unit + val preTycheck : unit -> unit + val badArgs : string * Ast.exp list -> 'a val badArg : string * string * Ast.exp -> 'a @@ -45,12 +49,17 @@ signature ENV = sig val int : int arg val string : string arg + val bool : bool arg val list : 'a arg -> 'a list arg val none : string -> (unit -> unit) -> action val one : string -> string * 'a arg -> ('a -> unit) -> action val two : string -> string * 'a arg * string * 'b arg -> ('a * 'b -> unit) -> action + val three : string + -> string * 'a arg * string * 'b arg * string * 'c arg + -> ('a * 'b * 'c -> unit) -> action + val noneV : string -> (env_vars -> unit) -> action val oneV : string -> string * 'a arg -> (env_vars * 'a -> unit) -> action val twoV : string -> string * 'a arg * string * 'b arg -> (env_vars * 'a * 'b -> unit) -> action @@ -61,6 +70,9 @@ signature ENV = sig val action_none : string -> (unit -> unit) -> unit val action_one : string -> string * 'a arg -> ('a -> unit) -> unit val action_two : string -> string * 'a arg * string * 'b arg -> ('a * 'b -> unit) -> unit + val action_three : string + -> string * 'a arg * string * 'b arg * string * 'c arg + -> ('a * 'b * 'c -> unit) -> unit val actionV_none : string -> (env_vars -> unit) -> unit val actionV_one : string -> string * 'a arg -> (env_vars * 'a -> unit) -> unit @@ -69,8 +81,12 @@ signature ENV = sig val container_none : string -> (unit -> unit) * (unit -> unit) -> unit val container_one : string -> string * 'a arg -> ('a -> unit) * (unit -> unit) -> unit + val containerV_none : string -> (env_vars -> unit) * (unit -> unit) -> unit val containerV_one : string -> string * 'a arg -> (env_vars * 'a -> unit) * (unit -> unit) -> unit + val registerFunction : string * (Ast.exp list -> Ast.exp option) -> unit + val function : string -> (Ast.exp list -> Ast.exp option) option + type env val empty : env