diff options
| author | Théo Zimmermann | 2020-05-13 19:48:08 +0200 |
|---|---|---|
| committer | Théo Zimmermann | 2020-05-13 19:48:08 +0200 |
| commit | b0e3404de4dff81680861517f70c496af1d92bbc (patch) | |
| tree | 1f6d9eea361a9e9bbdc5786343e74ffcfa9e96ae /doc/sphinx/language/core | |
| parent | c7b529cd79d56ba30d98a459e9f08ccd9910e236 (diff) | |
Create a new file on Variants.
Diffstat (limited to 'doc/sphinx/language/core')
| -rw-r--r-- | doc/sphinx/language/core/variants.rst | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/doc/sphinx/language/core/variants.rst b/doc/sphinx/language/core/variants.rst new file mode 100644 index 0000000000..fc2481201f --- /dev/null +++ b/doc/sphinx/language/core/variants.rst @@ -0,0 +1,24 @@ +Private (matching) inductive types +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +.. attr:: private(matching) + + This attribute can be used to forbid the use of the :g:`match` + construct on objects of this inductive type outside of the module + where it is defined. There is also a legacy syntax using the + ``Private`` prefix (cf. :n:`@legacy_attr`). + + The main use case of private (matching) inductive types is to emulate + quotient types / higher-order inductive types in projects such as + the `HoTT library <https://github.com/HoTT/HoTT>`_. + +.. example:: + + .. coqtop:: all + + Module Foo. + #[ private(matching) ] Inductive my_nat := my_O : my_nat | my_S : my_nat -> my_nat. + Check (fun x : my_nat => match x with my_O => true | my_S _ => false end). + End Foo. + Import Foo. + Fail Check (fun x : my_nat => match x with my_O => true | my_S _ => false end). |
