From 2abfa29636a8fdc184859d5445118df8d469df3b Mon Sep 17 00:00:00 2001
From: Ralf Jung <jung@mpi-sws.org>
Date: Wed, 14 Feb 2018 10:06:24 +0100
Subject: [PATCH] explain why we use typeclasses eauto

---
 theories/proofmode/tactics.v | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/theories/proofmode/tactics.v b/theories/proofmode/tactics.v
index ab862cc2b..c3be4ca67 100644
--- a/theories/proofmode/tactics.v
+++ b/theories/proofmode/tactics.v
@@ -629,6 +629,11 @@ Tactic Notation "iIntoValid" open_constr(t) :=
       let e' := eval unfold e in e in clear e; go (t e')
     | _ =>
       let tT' := eval cbv zeta in tT in eapply (as_valid_1 tT');
+        (* Doing [apply _] here fails because that will try to solve all evars
+        whose type is a typeclass, in dependency order (according to Matthieu).
+        If one fails, it aborts.  However, we rely on progress on the main goal
+        ([AsValid ...])  to unify some of these evars and hence enable progress
+        elsewhere.  With [typeclasses eauto], that seems to work better. *)
         [solve [ typeclasses eauto with typeclass_instances ] || fail "iPoseProof: not a BI assertion"|exact t]
     end in
   go t.
-- 
GitLab