aboutsummaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
authorErik Martin-Dorel2019-11-01 00:49:55 +0100
committerErik Martin-Dorel2019-11-01 04:43:12 +0100
commita37b6f81a3d3922dc89a179b50494d0bbd7afbf6 (patch)
tree6ebd1824adab4f45725fcd0953996581f2f7600e /doc
parent1090b272772c70a79fb082713451a935737cb1d3 (diff)
[ssr] Refactor/Extend of under to support more relations
(namely, [RewriteRelation]s beyond Equivalence ones) Thanks to @CohenCyril for suggesting this enhancement
Diffstat (limited to 'doc')
-rw-r--r--doc/changelog/06-ssreflect/10022-ssr-under-setoid.rst37
-rw-r--r--doc/stdlib/hidden-files1
2 files changed, 23 insertions, 15 deletions
diff --git a/doc/changelog/06-ssreflect/10022-ssr-under-setoid.rst b/doc/changelog/06-ssreflect/10022-ssr-under-setoid.rst
index e9eab0924c..5e005742fd 100644
--- a/doc/changelog/06-ssreflect/10022-ssr-under-setoid.rst
+++ b/doc/changelog/06-ssreflect/10022-ssr-under-setoid.rst
@@ -1,21 +1,28 @@
- Generalize tactics :tacn:`under` and :tacn:`over` for any registered
- setoid equality. More precisely, assume the given context lemma has
- type `forall f1 f2, .. -> (forall i, R1 (f1 i) (f2 i)) -> R2 f1 f2`.
- The first step performed by :tacn:`under` (since Coq 8.10) amounts
- to calling the tactic :tacn:`rewrite <rewrite (ssreflect)>`, which
+ relation. More precisely, assume the given context lemma has type
+ `forall f1 f2, .. -> (forall i, R1 (f1 i) (f2 i)) -> R2 f1 f2`. The
+ first step performed by :tacn:`under` (since Coq 8.10) amounts to
+ calling the tactic :tacn:`rewrite <rewrite (ssreflect)>`, which
itself relies on :tacn:`setoid_rewrite` if need be. So this step was
already compatible with a double implication or setoid equality for
the conclusion head symbol `R2`. But a further step consists in
tagging the generated subgoal `R1 (f1 i) (?f2 i)` to protect it from
- unwanted evar instantiation, and obtain a subgoal displayed as
- ``'Under[ f1 i ]``. In Coq 8.10, this second (convenience) step was
- only performed when `R1` was Leibniz' `eq` or `iff`. Now, it is also
- performed for any relation `R1` which has a ``RewriteRelation``
- instance as well as a ``RelationClasses.Reflexive`` instance. This
- generalized support for setoid relations is enabled as soon as we do
- both ``Require Import ssreflect.`` and ``Require Setoid.`` Finally,
- a rewrite rule ``UnderE`` has been added if one wants to "unprotect"
- the evar, and instantiate it manually with another rule than
- reflexivity (i.e., without using :tacn:`over`). See also Section
+ unwanted evar instantiation, and get `Under_rel _ R1 (f1 i) (?f2 i)`
+ that is displayed as ``'Under[ f1 i ]``. In Coq 8.10, this second
+ (convenience) step was only performed when `R1` was Leibniz' `eq` or
+ `iff`. Now, it is also performed for any relation `R1` which has a
+ ``RewriteRelation`` instance (a `RelationClasses.Reflexive` instance
+ being also needed so :tacn:`over` can discharge the ``'Under[ _ ]``
+ goal by instantiating the hidden evar.) Also, it is now possible to
+ manipulate `Under_rel _ R1 (f1 i) (?f2 i)` subgoals directly if `R1`
+ is a `PreOrder` relation or so, thanks to extra instances proving
+ that `Under_rel` preserves the properties of the `R1` relation.
+ These two features generalizing support for setoid-like relations is
+ enabled as soon as we do both ``Require Import ssreflect.`` and
+ ``Require Setoid.`` Finally, a rewrite rule ``UnderE`` has been
+ added if one wants to "unprotect" the evar, and instantiate it
+ manually with another rule than reflexivity (i.e., without using the
+ :tacn:`over` tactic nor the ``over`` rewrite rule). See also Section
:ref:`under_ssr` (`#10022 <https://github.com/coq/coq/pull/10022>`_,
- by Erik Martin-Dorel, with suggestions and review by Enrico Tassi).
+ by Erik Martin-Dorel, with suggestions and review by Enrico Tassi
+ and Cyril Cohen).
diff --git a/doc/stdlib/hidden-files b/doc/stdlib/hidden-files
index 4f8986984f..6699252cee 100644
--- a/doc/stdlib/hidden-files
+++ b/doc/stdlib/hidden-files
@@ -77,4 +77,5 @@ plugins/setoid_ring/Rings_Q.v
plugins/setoid_ring/Rings_R.v
plugins/setoid_ring/Rings_Z.v
plugins/setoid_ring/ZArithRing.v
+plugins/ssr/ssrunder.v
plugins/ssr/ssrsetoid.v