diff options
author | Adam Chlipala <adam@chlipala.net> | 2013-08-19 12:38:43 -0400 |
---|---|---|
committer | Adam Chlipala <adam@chlipala.net> | 2013-08-19 12:38:43 -0400 |
commit | 0c89ee7ead6a2108f9496e06baffa77c62e47556 (patch) | |
tree | 716b2e80fc50d94f43e6543a244c67ca906131bd | |
parent | f718e640c3cbe6a891519364992117f49ca333fa (diff) |
Potentially exponential search through where to head-normalize in [decompileCon]
-rw-r--r-- | src/elaborate.sml | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/src/elaborate.sml b/src/elaborate.sml index 18010244..45aca382 100644 --- a/src/elaborate.sml +++ b/src/elaborate.sml @@ -3553,11 +3553,16 @@ and wildifyStr env (str, sgn) = | L'.KFun _ => NONE fun maybeHnorm env c = - hnormCon env c - handle E.UnboundNamed _ => c + hnormCon env c + handle E.UnboundNamed _ => c - fun decompileCon env (c as (_, loc)) = - case #1 (maybeHnorm env c) of + fun decompileCon env c = + case decompileCon' env c of + SOME v => SOME v + | NONE => decompileCon' env (maybeHnorm env c) + + and decompileCon' env (c as (_, loc)) = + case #1 c of L'.CRel i => let val (s, _) = E.lookupCRel env i @@ -3619,6 +3624,10 @@ and wildifyStr env (str, sgn) = end | L'.CMap _ => SOME (L.CMap, loc) + | L'.TRecord c => + (case decompileCon env c of + NONE => NONE + | SOME c' => SOME (L.TRecord c', loc)) | c => (Print.preface ("WTF?", p_con env (c, loc)); NONE) |