- buf <- hGetStringBuffer True{-expand tabs-} src_filename
-
- let glaexts | dopt Opt_GlasgowExts dflags = 1#
- | otherwise = 0#
-
- case parse buf PState{ bol = 0#, atbol = 1#,
- context = [], glasgow_exts = glaexts,
- loc = mkSrcLoc src_filename 1 } of {
-
- PFailed err -> return (HscErrs pcs (unitBag err) emptyBag)
-
- POk _ rdr_module@(HsModule mod_name _ _ _ _ _ _) ->
-
- dumpIfSet (dopt_D_dump_parsed flags) "Parser" (ppr rdr_module) >>
-
- dumpIfSet (dopt_D_source_stats flags) "Source Statistics"
- (ppSourceStats False rdr_module) >>
-
- -- UniqueSupplies for later use (these are the only lower case uniques)
- mkSplitUniqSupply 'd' >>= \ ds_uniqs -> -- desugarer
- mkSplitUniqSupply 'r' >>= \ ru_uniqs -> -- rules
- mkSplitUniqSupply 'c' >>= \ c2s_uniqs -> -- core-to-stg
- mkSplitUniqSupply 'g' >>= \ st_uniqs -> -- stg-to-stg passes
- mkSplitUniqSupply 'n' >>= \ ncg_uniqs -> -- native-code generator
-
- -------------------------- Rename ----------------
- show_pass "Renamer" >>
- _scc_ "Renamer"
-
- renameModule dflags finder pcs hst rdr_module
- >>= \ (pcs_rn, maybe_rn_stuff) ->
- case maybe_rn_stuff of {
- Nothing -> -- Hurrah! Renamer reckons that there's no need to
- -- go any further
- reportCompile mod_name "Compilation NOT required!" >>
- return ();
-
- Just (this_mod, rn_mod,
- old_iface, new_iface,
- rn_name_supply, fixity_env,
- imported_modules) ->
- -- Oh well, we've got to recompile for real
-
-
- -------------------------- Typechecking ----------------
- show_pass "TypeCheck" >>
- _scc_ "TypeCheck"
- typecheckModule dflags mod pcs hst hit pit rn_mod
- -- tc_uniqs rn_name_supply
- -- fixity_env rn_mod
- >>= \ maybe_tc_stuff ->
- case maybe_tc_stuff of {
- Nothing -> ghcExit 1; -- Type checker failed
-
- Just (tc_results@(TcResults {tc_tycons = local_tycons,
- tc_classes = local_classes,
- tc_insts = inst_info })) ->
-
-
- -------------------------- Desugaring ----------------
- _scc_ "DeSugar"
- deSugar this_mod ds_uniqs tc_results >>= \ (desugared, rules, h_code, c_code, fe_binders) ->
-
-
- -------------------------- Main Core-language transformations ----------------
- _scc_ "Core2Core"
- core2core core_cmds desugared rules >>= \ (simplified, orphan_rules) ->
-
- -- Do the final tidy-up
- tidyCorePgm this_mod
- simplified orphan_rules >>= \ (tidy_binds, tidy_orphan_rules) ->
-
- -- Run the occurrence analyser one last time, so that
- -- dead binders get dead-binder info. This is exploited by
- -- code generators to avoid spitting out redundant bindings.
- -- The occurrence-zapping in Simplify.simplCaseBinder means
- -- that the Simplifier nukes useful dead-var stuff especially
- -- in case patterns.
- let occ_anal_tidy_binds = occurAnalyseBinds tidy_binds in
-
- coreBindsSize occ_anal_tidy_binds `seq`
--- TEMP: the above call zaps some space usage allocated by the
--- simplifier, which for reasons I don't understand, persists
--- thoroughout code generation
-
-
-
- -------------------------- Convert to STG code -------------------------------
- show_pass "Core2Stg" >>
- _scc_ "Core2Stg"
- let
- stg_binds = topCoreBindsToStg c2s_uniqs occ_anal_tidy_binds
- in
-
- -------------------------- Simplify STG code -------------------------------
- show_pass "Stg2Stg" >>
- _scc_ "Stg2Stg"
- stg2stg stg_cmds this_mod st_uniqs stg_binds >>= \ (stg_binds2, cost_centre_info) ->
-
-#ifdef GHCI
- runStgI local_tycons local_classes
- (map fst stg_binds2) >>= \ i_result ->
- putStr ("\nANSWER = " ++ show i_result ++ "\n\n")
- >>
-
-#else
- -------------------------- Interface file -------------------------------
- -- Dump instance decls and type signatures into the interface file
- _scc_ "Interface"
- let
- final_ids = collectFinalStgBinders (map fst stg_binds2)
- in
- writeIface this_mod old_iface new_iface
- local_tycons local_classes inst_info
- final_ids occ_anal_tidy_binds tidy_orphan_rules >>
-
-
- -------------------------- Code generation -------------------------------
- show_pass "CodeGen" >>
- _scc_ "CodeGen"
- codeGen this_mod imported_modules
- cost_centre_info
- fe_binders
- local_tycons local_classes
- stg_binds2 >>= \ abstractC ->
-
-
- -------------------------- Code output -------------------------------
- show_pass "CodeOutput" >>
- _scc_ "CodeOutput"
- codeOutput this_mod local_tycons local_classes
- occ_anal_tidy_binds stg_binds2
- c_code h_code abstractC
- ncg_uniqs >>
-
-
- -------------------------- Final report -------------------------------
- reportCompile mod_name (showSDoc (ppSourceStats True rdr_module)) >>
-
-#endif
-
-
- ghcExit 0
- } }
- where
- -------------------------------------------------------------
- -- ****** help functions:
-
- show_pass
- = if opt_D_show_passes
- then \ what -> hPutStr stderr ("*** "++what++":\n")
- else \ what -> return ()
--- END old stuff
-#endif