From d2fd1f217310deb08d5132afab3e0f75a802d9bd Mon Sep 17 00:00:00 2001 From: Brian Huffman Date: Mon, 3 Aug 2015 10:37:31 -0700 Subject: [PATCH] Run the renamer on parsed cryptol types. Fixes #37. Parsing something like {| Bit |} now properly refers to type Bit from the Cryptol prelude. --- src/SAWScript/CryptolEnv.hs | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/src/SAWScript/CryptolEnv.hs b/src/SAWScript/CryptolEnv.hs index ae3cfa14e8..b1e267745b 100644 --- a/src/SAWScript/CryptolEnv.hs +++ b/src/SAWScript/CryptolEnv.hs @@ -372,13 +372,20 @@ parseSchema :: CryptolEnv s -> Located String -> IO T.Schema parseSchema env input = do --putStrLn $ "parseSchema: " ++ show input let modEnv = eModuleEnv env + + -- | Parse pschema <- ioParseSchema input --putStrLn $ "ioParseSchema: " ++ show pschema + + -- | Resolve names + let nameEnv = MR.namingEnv pschema `MR.shadowing` getNamingEnv env + (rschema, _) <- liftModuleM modEnv (MM.interactive (MB.rename nameEnv pschema)) + let ifDecls = getAllIfaceDecls modEnv - let range = fromMaybe P.emptyRange (P.getLoc pschema) + let range = fromMaybe P.emptyRange (P.getLoc rschema) (tcEnv, _) <- liftModuleM modEnv $ MB.genInferInput range ifDecls let tcEnv' = tcEnv { TM.inpTSyns = Map.union (eExtraTSyns env) (TM.inpTSyns tcEnv) } - out <- TM.runInferM tcEnv' (TK.checkSchema pschema) + out <- TM.runInferM tcEnv' (TK.checkSchema rschema) ((schema, goals), _) <- liftModuleM modEnv (MM.interactive (runInferOutput out)) unless (null goals) (print goals) return schema