module Command: sig
.. end
type
tags = Tags.t
type
pathname = string
val jobs : int Pervasives.ref
type
t =
| |
Seq of t list |
| |
Cmd of spec |
| |
Echo of string list * pathname |
| |
Nop |
type
spec =
| |
N |
| |
S of spec list |
| |
A of string |
| |
P of pathname |
| |
Px of pathname |
| |
Sh of string |
| |
T of Tags.t |
| |
V of string |
| |
Quote of spec |
val no_tag_handler : 'a -> 'b
val tag_handler : (Tags.t -> spec) Pervasives.ref
val atomize : string list -> spec
val atomize_paths : pathname list -> spec
val env_path : string list lazy_t
val virtual_solvers : (string, unit -> spec) Hashtbl.t
val setup_virtual_command_solver : string -> (unit -> spec) -> unit
val virtual_solver : string -> spec
val search_in_path : string -> string
val string_of_command_spec_with_calls : (Tags.t -> 'a) ->
(pathname -> unit) -> bool -> spec -> string
val string_of_command_spec : spec -> string
val string_target_and_tags_of_command_spec : spec -> string * pathname * Tags.t
val string_print_of_command_spec : spec -> bool -> bool -> unit -> string
val print_escaped_string : Format.formatter -> string -> unit
val print : Format.formatter -> t -> unit
val to_string : t -> string
module Primitives: sig
.. end
val list_rev_iter : ('a -> unit) -> 'a list -> unit
val flatten_commands : bool -> bool -> t -> (unit -> string) list
val execute_many : ?quiet:bool -> ?pretend:bool -> t list -> (bool list * exn) option
val execute : ?quiet:bool -> ?pretend:bool -> t -> unit
val iter_tags : (Tags.t -> unit) -> t -> unit
val fold_pathnames : (pathname -> 'a -> 'a) -> t -> 'a -> 'a
val reduce : spec -> spec
val digest : t -> My_std.Digest.t
val all_deps_of_tags : (Tags.t * pathname list) list Pervasives.ref
val cons : 'a list -> 'a list -> 'a list
val deps_of_tags : Tags.t -> pathname list
val set_deps_of_tags : Tags.t -> pathname list -> unit
val dep : string list -> pathname list -> unit
val pdep : Tags.elt list -> Tags.elt -> (string -> pathname list) -> unit