aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/elaborate.sml
diff options
context:
space:
mode:
authorGravatar Adam Chlipala <adam@chlipala.net>2012-05-02 08:56:19 -0400
committerGravatar Adam Chlipala <adam@chlipala.net>2012-05-02 08:56:19 -0400
commit1fd7e4392db0bace167853850188c464b00a8126 (patch)
tree62439e548ac25411e953783beb116b5937e87fae /src/elaborate.sml
parentb314c01095c5cd4617f71f706e43530a57ffb65b (diff)
Don't modify the module cache after elaboration failures
Diffstat (limited to 'src/elaborate.sml')
-rw-r--r--src/elaborate.sml7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/elaborate.sml b/src/elaborate.sml
index 26ec21ec..41e9e9ab 100644
--- a/src/elaborate.sml
+++ b/src/elaborate.sml
@@ -4461,6 +4461,8 @@ fun resolveClass env = E.resolveClass (hnormCon env) (consEq env dummy) env
fun elabFile basis basis_tm topStr topSgn top_tm env file =
let
+ val () = ModDb.snapshot ()
+
val () = mayDelay := true
val () = delayedUnifs := []
val () = delayedExhaustives := []
@@ -4788,6 +4790,11 @@ fun elabFile basis basis_tm topStr topSgn top_tm env file =
end
else
();
+
+ if ErrorMsg.anyErrors () then
+ ModDb.revert ()
+ else
+ ();
(L'.DFfiStr ("Basis", basis_n, sgn), ErrorMsg.dummySpan)
:: ds