X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=Translator.hs;h=550b4f0800475b348d4a6146aa317527d74af79d;hb=998e440a7fa765685e1ed500c871058a33129b1f;hp=92251eede3caf0dde2915ae9cf006f9078ce638f;hpb=2fc713015ccdabfb4f979546c3ecd0dd40329bb8;p=matthijs%2Fmaster-project%2Fc%CE%BBash.git diff --git a/Translator.hs b/Translator.hs index 92251ee..550b4f0 100644 --- a/Translator.hs +++ b/Translator.hs @@ -8,6 +8,9 @@ import qualified Var import qualified Type import qualified TyCon import qualified DataCon +import qualified HscMain +import qualified SrcLoc +import qualified FastString import qualified Maybe import qualified Module import qualified Data.Foldable as Foldable @@ -45,8 +48,8 @@ import FlattenTypes import VHDLTypes import qualified VHDL -main = do - makeVHDL "Alu.hs" "register_bank" True +-- main = do +-- makeVHDL "Alu.hs" "exec" True makeVHDL :: String -> String -> Bool -> IO () makeVHDL filename name stateful = do @@ -63,11 +66,13 @@ makeVHDL filename name stateful = do listBind :: String -> String -> IO () listBind filename name = do core <- loadModule filename - let binds = findBinds core [name] + let [(b, expr)] = findBinds core [name] putStr "\n" - putStr $ prettyShow binds + putStr $ prettyShow expr putStr "\n\n" - putStr $ showSDoc $ ppr binds + putStr $ showSDoc $ ppr expr + putStr "\n\n" + putStr $ showSDoc $ ppr $ CoreUtils.exprType expr putStr "\n\n" -- | Translate the binds with the given names from the given core module to @@ -86,7 +91,7 @@ moduleToVHDL core list = do return vhdl where -- Turns the given bind into VHDL - mkVHDL :: [CoreBind] -> [Bool] -> TranslatorState [(AST.VHDLId, AST.DesignFile)] + mkVHDL :: [(CoreBndr, CoreExpr)] -> [Bool] -> TranslatorState [(AST.VHDLId, AST.DesignFile)] mkVHDL binds statefuls = do -- Add the builtin functions --mapM addBuiltIn builtin_funcs @@ -125,28 +130,24 @@ loadModule filename = return core -- | Extracts the named binds from the given module. -findBinds :: HscTypes.CoreModule -> [String] -> [CoreBind] -findBinds core names = Maybe.mapMaybe (findBind (cm_binds core)) names +findBinds :: HscTypes.CoreModule -> [String] -> [(CoreBndr, CoreExpr)] +findBinds core names = Maybe.mapMaybe (findBind (CoreSyn.flattenBinds $ cm_binds core)) names -- | Extract a named bind from the given list of binds -findBind :: [CoreBind] -> String -> Maybe CoreBind +findBind :: [(CoreBndr, CoreExpr)] -> String -> Maybe (CoreBndr, CoreExpr) findBind binds lookfor = -- This ignores Recs and compares the name of the bind with lookfor, -- disregarding any namespaces in OccName and extra attributes in Name and -- Var. - find (\b -> case b of - Rec l -> False - NonRec var _ -> lookfor == (occNameString $ nameOccName $ getName var) - ) binds + find (\(var, _) -> lookfor == (occNameString $ nameOccName $ getName var)) binds -- | Processes the given bind as a top level bind. processBind :: Bool -- ^ Should this be stateful function? - -> CoreBind -- ^ The bind to process + -> (CoreBndr, CoreExpr) -- ^ The bind to process -> TranslatorState () -processBind _ (Rec _) = error "Recursive binders not supported" -processBind stateful bind@(NonRec var expr) = do +processBind stateful bind@(var, expr) = do -- Create the function signature let ty = CoreUtils.exprType expr let hsfunc = mkHsFunction var ty stateful @@ -157,18 +158,16 @@ processBind stateful bind@(NonRec var expr) = do -- with them. flattenBind :: HsFunction -- The signature to flatten into - -> CoreBind -- The bind to flatten + -> (CoreBndr, CoreExpr) -- The bind to flatten -> TranslatorState () -flattenBind _ (Rec _) = error "Recursive binders not supported" - -flattenBind hsfunc bind@(NonRec var expr) = do +flattenBind hsfunc bind@(var, expr) = do -- Flatten the function let flatfunc = flattenFunction hsfunc bind -- Propagate state variables let flatfunc' = propagateState hsfunc flatfunc -- Store the flat function in the session - modA tsFlatFuncs (Map.insert hsfunc flatfunc) + modA tsFlatFuncs (Map.insert hsfunc flatfunc') -- Flatten any functions used let used_hsfuncs = Maybe.mapMaybe usedHsFunc (flat_defs flatfunc') mapM_ resolvFunc used_hsfuncs @@ -276,7 +275,7 @@ resolvFunc hsfunc = do core <- getA tsCoreModule -- Find the named function let name = (hsFuncName hsfunc) - let bind = findBind (cm_binds core) name + let bind = findBind (CoreSyn.flattenBinds $ cm_binds core) name case bind of Nothing -> error $ "Couldn't find function " ++ name ++ " in current module." Just b -> flattenBind hsfunc b