package rocq-runtime
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=b236dc44f92e1eeca6877c7ee188a90c2303497fe7beb99df711ed5a7ce0d824
doc/rocq-runtime.library/Goptions/index.html
Module Goptions
Source
This module manages customization parameters at the vernacular level
Two kinds of things are managed : tables and options value
- Tables are created by applying the
MakeTable
functor. - Variables storing options value are created by applying one of the
declare_int_option
,declare_bool_option
, ... functions.
Each table/option is uniquely identified by a key of type option_name
which consists in a list of strings. Note that for parsing constraints, table names must not be made of more than 2 strings while option names can be of arbitrary length.
The declaration of a table, say of name ["Toto";"Titi"]
automatically makes available the following vernacular commands:
Add Toto Titi foo. Remove Toto Titi foo. Print Toto Titi. Test Toto Titi.
The declaration of a non boolean option value, say of name ["Tata";"Tutu";"Titi"]
, automatically makes available the following vernacular commands:
Set Tata Tutu Titi val. Print Table Tata Tutu Titi.
If it is the declaration of a boolean value, the following vernacular commands are made available:
Set Tata Tutu Titi. Unset Tata Tutu Titi. Print Table Tata Tutu Titi. (** synonym: Test Table Tata Tutu Titi. *)
All options are synchronized with the document.
type _ option_kind =
| BoolKind : bool option_kind
| IntKind : int option option_kind
| StringKind : string option_kind
| StringOptKind : string option option_kind
Tables.
The functor MakeStringTable
declares a table containing objects of type string
; the function member_message
say what to print when invoking the "Test Toto Titi foo." command; at the end title
is the table name printed when invoking the "Print Toto Titi." command; active
is roughly the internal version of the vernacular "Test ...": it tells if a given object is in the table; elements
returns the list of elements of the table
The functor MakeRefTable
declares a new table of objects of type A.t
practically denoted by reference
; the encoding function encode : env -> reference -> A.t
is typically a globalization function, possibly with some restriction checks; the function member_message
say what to print when invoking the "Test Toto Titi foo." command; at the end title
is the table name printed when invoking the "Print Toto Titi." command; active
is roughly the internal version of the vernacular "Test ...": it tells if a given object is in the table.
Options.
These types and function are for declaring a new option of name key
and access functions read
and write
; the parameter name
is the option name used when printing the option value (command "Print Toto Titi."
The declare_*_option functions are low-level, to be used when implementing complex option workflows, e.g. when the option data is in the global env. For most use cases, you should use the helper functions declare_*_option_and_ref.
type 'a option_sig = {
optstage : Summary.Stage.t;
optdepr : Deprecation.t option;
(*whether the option is DEPRECATED
*)optkey : option_name;
(*the low-level name of this option
*)optread : unit -> 'a;
optwrite : 'a -> unit;
}
val declare_option :
?preprocess:('a -> 'a) ->
?no_summary:bool ->
kind:'a option_kind ->
'a option_sig ->
unit
The preprocess
function is triggered before setting the option. It can be used to emit a warning on certain values, and clean-up the final value.
By default no_summary:false
, and declare_option declares a summary entry to synchronize the backing state by calling read and write. If you pass no_summary:true
you must handle synchronization separately.
StringOptKind
should be preferred to StringKind
because it supports "Unset".
val declare_append_only_option :
?preprocess:(string -> string) ->
sep:string ->
string option_sig ->
unit
Helpers to declare a reference controlled by an option.
Wrapper type to separate the function calls to register the option at toplevel from the calls to read the option value.
type 'a opt_decl =
?stage:Summary.Stage.t ->
?depr:Deprecation.t ->
key:option_name ->
value:'a ->
unit ->
'a getter
Special functions supposed to be used only in vernacentries.ml
type 'a table_of_A = {
add : Environ.env -> Libobject.locality -> 'a -> unit;
remove : Environ.env -> Libobject.locality -> 'a -> unit;
mem : Environ.env -> 'a -> unit;
print : unit -> unit;
}
val set_int_option_value_gen :
?locality:option_locality ->
?stage:Summary.Stage.t ->
option_name ->
int option ->
unit
The first argument is a locality flag. If stage
is provided, the option is set/unset only if it is declared in the corresponding stage. If omitted, the option is always set/unset.
val set_bool_option_value_gen :
?locality:option_locality ->
?stage:Summary.Stage.t ->
option_name ->
bool ->
unit
val set_string_option_value_gen :
?locality:option_locality ->
?stage:Summary.Stage.t ->
option_name ->
string ->
unit
val unset_option_value_gen :
?locality:option_locality ->
?stage:Summary.Stage.t ->
option_name ->
unit
get_option_value key
returns None
if option with name key
was not found.
val set_option_value :
?locality:option_locality ->
?stage:Summary.Stage.t ->
'a check_and_cast ->
option_name ->
'a ->
unit
set_option_value ?locality f name v
sets name
to the result of applying f
to v
and name
's option kind. Use for behaviour depending on the type of the option, eg erroring when 'a
doesn't match it.
Summary of an option status
Compat
val declare_int_option :
?preprocess:(int option -> int option) ->
int option option_sig ->
unit
val declare_stringopt_option :
?preprocess:(string option -> string option) ->
string option option_sig ->
unit