package rocq-runtime
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=051f7bf702ff0a3b370449728921e5a95e18bc2b31b8eb949d48422888c98af4
doc/ltac2_plugin/Ltac2_plugin/Tac2val/index.html
Module Ltac2_plugin.Tac2valSource
Toplevel values
Dynamic semantics
Values are represented in a way similar to OCaml, i.e. they contrast immediate integers (integers, constructors without arguments) and structured blocks (tuples, arrays, constructors with arguments), as well as a few other base cases, namely closures, strings, named constructors, and dynamic type coming from the Rocq implementation.
type valexpr = | ValInt of int(*Immediate integers
*)| ValBlk of tag * valexpr array(*Structured blocks
*)| ValStr of Stdlib.Bytes.t(*Strings
*)| ValCls of closure(*Closures
*)| ValOpn of Names.KerName.t * valexpr array(*Open constructors
*)| ValExt : 'a Tac2dyn.Val.tag * 'a -> valexpr(*Arbitrary data
*)
Closures
The arrows in 'v should be pure. Use tclLIFT or do tclUNIT () >>= fun () -> f args when you need effects.
The closure must not be already annotated
For internal use (Tac2externals). Wraps the applications of the 'v argument to make it pure.
Given a closure, apply it to some arguments. Handling of argument mismatches is done automatically, i.e. in case of over or under-application.
Composition of to_closure and apply
Turn a fixed-arity function into a closure. The inner function is guaranteed to be applied to a list whose size is the integer argument.