blob: e535c1925253e22462acf147ff1cddcf22dc8146 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
(************************************************************************)
(* * The Coq Proof Assistant / The Coq Development Team *)
(* v * Copyright INRIA, CNRS and contributors *)
(* <O___,, * (see version control and CREDITS file for authors & dates) *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(* * (see LICENSE file for the text of the license) *)
(************************************************************************)
(** Definition of custom toplevels.
[init] is used to do custom command line argument parsing.
[run] launches a custom toplevel.
*)
type 'a extra_args_fn = opts:Coqargs.t -> string list -> 'a * string list
type ('a,'b) custom_toplevel =
{ parse_extra : 'a extra_args_fn
; help : Usage.specific_usage
; init : 'a -> opts:Coqargs.t -> 'b
; run : 'a -> opts:Coqargs.t -> 'b -> unit
; opts : Coqargs.t
}
(** The generic Coq main module. [start custom] will parse the command line,
print the banner, initialize the load path, load the input state,
load the files given on the command line, load the resource file,
produce the output state if any, and finally will launch
[custom.run]. *)
val start_coq : ('a,'b) custom_toplevel -> unit
(** Initializer color for output *)
val init_color : Coqargs.coqargs_config -> unit
(** Prepare state for interactive loop *)
val init_toploop : Coqargs.t -> Vernac.State.t
(** The specific characterization of the coqtop_toplevel *)
type run_mode = Interactive | Batch
val coqtop_toplevel : (run_mode,Vernac.State.t) custom_toplevel
|