package rocq-runtime
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=b236dc44f92e1eeca6877c7ee188a90c2303497fe7beb99df711ed5a7ce0d824
doc/rocq-runtime.library/Goptions/index.html
Module GoptionsSource
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
MakeTablefunctor. - 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 ->
unitThe 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 ->
unitHelpers 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 getterSpecial 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 ->
unitThe 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 ->
unitval set_string_option_value_gen :
?locality:option_locality ->
?stage:Summary.Stage.t ->
option_name ->
string ->
unitval unset_option_value_gen :
?locality:option_locality ->
?stage:Summary.Stage.t ->
option_name ->
unitget_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 ->
unitset_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 ->
unitval declare_stringopt_option :
?preprocess:(string option -> string option) ->
string option option_sig ->
unit