import HsSyn
import TcRnTypes
import MkIface
+import IfaceEnv
import Id
import Pair
import Name
+import FastString
import CoreSyn
import CoreSubst
import CoqPass ( coqPassCoreToString, coqPassCoreToCore )
<- case target of
HscNothing ->
return (emptyMessages,
- Just ([], nilOL, [], [], NoStubs, hpcInfo, emptyModBreaks, undefined, undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- , undefined
- ))
+ Just ([], nilOL, [], [], NoStubs, hpcInfo, emptyModBreaks, undefined))
_ -> do
(binds_cvr,ds_hpc_info, modBreaks)
<- if (opt_Hpc
then addCoverageTicksToBinds dflags mod mod_loc
(typeEnvTyCons type_env) binds
else return (binds, hpcInfo, emptyModBreaks)
+
initDs hsc_env mod rdr_env type_env $ do
do { ds_ev_binds <- dsEvBinds ev_binds
; core_prs <- dsTopLHsBinds auto_scc binds_cvr
; (ds_fords, foreign_prs) <- dsForeigns fords
; ds_rules <- mapMaybeM dsRule rules
; ds_vects <- mapM dsVect vects
- ; hetmet_brak <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_brak_name else return undefined
- ; hetmet_esc <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_esc_name else return undefined
- ; hetmet_flatten <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_flatten_name else return undefined
- ; hetmet_unflatten <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_unflatten_name else return undefined
- ; hetmet_flattened_id <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_flattened_id_name else return undefined
- ; hetmet_PGArrow <- if dopt Opt_F_coqpass dflags then dsLookupTyCon hetmet_PGArrow_name else return undefined
- ; hetmet_PGArrow_unit <- if dopt Opt_F_coqpass dflags then dsLookupTyCon hetmet_PGArrow_unit_name else return undefined
- ; hetmet_PGArrow_tensor <- if dopt Opt_F_coqpass dflags then dsLookupTyCon hetmet_PGArrow_tensor_name else return undefined
- ; hetmet_PGArrow_exponent <- if dopt Opt_F_coqpass dflags then dsLookupTyCon hetmet_PGArrow_exponent_name else return undefined
- ; hetmet_pga_id <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_id_name else return undefined
- ; hetmet_pga_comp <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_comp_name else return undefined
- ; hetmet_pga_first <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_first_name else return undefined
- ; hetmet_pga_second <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_second_name else return undefined
- ; hetmet_pga_cancell <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_cancell_name else return undefined
- ; hetmet_pga_cancelr <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_cancelr_name else return undefined
- ; hetmet_pga_uncancell <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_uncancell_name else return undefined
- ; hetmet_pga_uncancelr <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_uncancelr_name else return undefined
- ; hetmet_pga_assoc <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_assoc_name else return undefined
- ; hetmet_pga_unassoc <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_unassoc_name else return undefined
- ; hetmet_pga_copy <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_copy_name else return undefined
- ; hetmet_pga_drop <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_drop_name else return undefined
- ; hetmet_pga_swap <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_swap_name else return undefined
- ; hetmet_pga_applyl <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_applyl_name else return undefined
- ; hetmet_pga_applyr <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_applyr_name else return undefined
- ; hetmet_pga_curryl <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_curryl_name else return undefined
- ; hetmet_pga_curryr <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_curryr_name else return undefined
- ; hetmet_pga_loopl <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_loopl_name else return undefined
- ; hetmet_pga_loopr <- if dopt Opt_F_coqpass dflags then dsLookupGlobalId hetmet_pga_loopr_name else return undefined
+ ; junk <- if dopt Opt_F_coqpass dflags
+ then do { hetmet_brak_name <- lookupOrig gHC_HETMET_CODETYPES (mkOccNameFS varName (fsLit "hetmet_brak"))
+ ; hetmet_brak <- dsLookupGlobalId hetmet_brak_name
+ ; hetmet_esc_name <- lookupOrig gHC_HETMET_CODETYPES (mkOccNameFS varName (fsLit "hetmet_esc"))
+ ; hetmet_esc <- dsLookupGlobalId hetmet_esc_name
+ ; hetmet_flatten_name <- lookupOrig gHC_HETMET_CODETYPES (mkOccNameFS varName (fsLit "hetmet_flatten"))
+ ; hetmet_flatten <- dsLookupGlobalId hetmet_flatten_name
+ ; hetmet_unflatten_name <- lookupOrig gHC_HETMET_CODETYPES (mkOccNameFS varName (fsLit "pga_unflatten"))
+ ; hetmet_unflatten <- dsLookupGlobalId hetmet_unflatten_name
+ ; hetmet_flattened_id_name <- lookupOrig gHC_HETMET_CODETYPES (mkOccNameFS varName (fsLit "pga_flattened_id"))
+ ; hetmet_flattened_id <- dsLookupGlobalId hetmet_flattened_id_name
+ ; hetmet_PGArrow_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS tcName (fsLit "PGArrow"))
+ ; hetmet_PGArrow <- dsLookupTyCon hetmet_PGArrow_name
+ ; hetmet_PGArrow_unit_name <- lookupOrig gHC_HETMET_GARROW (mkOccNameFS tcName (fsLit "GArrowUnit"))
+ ; hetmet_PGArrow_unit <- dsLookupTyCon hetmet_PGArrow_unit_name
+ ; hetmet_PGArrow_tensor_name <- lookupOrig gHC_HETMET_GARROW (mkOccNameFS tcName (fsLit "GArrowTensor"))
+ ; hetmet_PGArrow_tensor <- dsLookupTyCon hetmet_PGArrow_tensor_name
+ ; hetmet_PGArrow_exponent_name <- lookupOrig gHC_HETMET_GARROW (mkOccNameFS tcName (fsLit "GArrowExponent"))
+ ; hetmet_PGArrow_exponent <- dsLookupTyCon hetmet_PGArrow_exponent_name
+ ; hetmet_pga_id_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_id"))
+ ; hetmet_pga_id <- dsLookupGlobalId hetmet_pga_id_name
+ ; hetmet_pga_comp_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_comp"))
+ ; hetmet_pga_comp <- dsLookupGlobalId hetmet_pga_comp_name
+ ; hetmet_pga_first_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_first"))
+ ; hetmet_pga_first <- dsLookupGlobalId hetmet_pga_first_name
+ ; hetmet_pga_second_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_second"))
+ ; hetmet_pga_second <- dsLookupGlobalId hetmet_pga_second_name
+ ; hetmet_pga_cancell_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_cancell"))
+ ; hetmet_pga_cancell <- dsLookupGlobalId hetmet_pga_cancell_name
+ ; hetmet_pga_cancelr_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_cancelr"))
+ ; hetmet_pga_cancelr <- dsLookupGlobalId hetmet_pga_cancelr_name
+ ; hetmet_pga_uncancell_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_uncancell"))
+ ; hetmet_pga_uncancell <- dsLookupGlobalId hetmet_pga_uncancell_name
+ ; hetmet_pga_uncancelr_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_uncancelr"))
+ ; hetmet_pga_uncancelr <- dsLookupGlobalId hetmet_pga_uncancelr_name
+ ; hetmet_pga_assoc_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_assoc"))
+ ; hetmet_pga_assoc <- dsLookupGlobalId hetmet_pga_assoc_name
+ ; hetmet_pga_unassoc_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_unassoc"))
+ ; hetmet_pga_unassoc <- dsLookupGlobalId hetmet_pga_unassoc_name
+ ; hetmet_pga_copy_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_copy"))
+ ; hetmet_pga_copy <- dsLookupGlobalId hetmet_pga_copy_name
+ ; hetmet_pga_drop_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_drop"))
+ ; hetmet_pga_drop <- dsLookupGlobalId hetmet_pga_drop_name
+ ; hetmet_pga_swap_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_swap"))
+ ; hetmet_pga_swap <- dsLookupGlobalId hetmet_pga_swap_name
+ ; hetmet_pga_applyl_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_applyl"))
+ ; hetmet_pga_applyl <- dsLookupGlobalId hetmet_pga_applyl_name
+ ; hetmet_pga_applyr_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_applyr"))
+ ; hetmet_pga_applyr <- dsLookupGlobalId hetmet_pga_applyr_name
+ ; hetmet_pga_curryl_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_curryl"))
+ ; hetmet_pga_curryl <- dsLookupGlobalId hetmet_pga_curryl_name
+ ; hetmet_pga_curryr_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_curryr"))
+ ; hetmet_pga_curryr <- dsLookupGlobalId hetmet_pga_curryr_name
+ ; hetmet_pga_loopl_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_loopl"))
+ ; hetmet_pga_loopl <- dsLookupGlobalId hetmet_pga_loopl_name
+ ; hetmet_pga_loopr_name <- lookupOrig gHC_HETMET_PRIVATE (mkOccNameFS varName (fsLit "pga_loopr"))
+ ; hetmet_pga_loopr <- dsLookupGlobalId hetmet_pga_loopr_name
+ ; return ( hetmet_brak
+ , hetmet_esc
+ , hetmet_flatten
+ , hetmet_unflatten
+ , hetmet_flattened_id
+ , hetmet_PGArrow
+ , hetmet_PGArrow_unit
+ , hetmet_PGArrow_tensor
+ , hetmet_PGArrow_exponent
+ , hetmet_pga_id
+ , hetmet_pga_comp
+ , hetmet_pga_first
+ , hetmet_pga_second
+ , hetmet_pga_cancell
+ , hetmet_pga_cancelr
+ , hetmet_pga_uncancell
+ , hetmet_pga_uncancelr
+ , hetmet_pga_assoc
+ , hetmet_pga_unassoc
+ , hetmet_pga_copy
+ , hetmet_pga_drop
+ , hetmet_pga_swap
+ , hetmet_pga_applyl
+ , hetmet_pga_applyr
+ , hetmet_pga_curryl
+ , hetmet_pga_curryr
+ , hetmet_pga_loopl
+ , hetmet_pga_loopr )
+ }
+ else return undefined
; let hpc_init
| opt_Hpc = hpcInitCode mod ds_hpc_info
| otherwise = empty
, foreign_prs `appOL` core_prs `appOL` spec_prs
, spec_rules ++ ds_rules, ds_vects
, ds_fords `appendStubC` hpc_init
- , ds_hpc_info, modBreaks, hetmet_brak, hetmet_esc
- , hetmet_flatten
- , hetmet_unflatten
- , hetmet_flattened_id
- , hetmet_PGArrow
- , hetmet_PGArrow_unit
- , hetmet_PGArrow_tensor
- , hetmet_PGArrow_exponent
- , hetmet_pga_id
- , hetmet_pga_comp
- , hetmet_pga_first
- , hetmet_pga_second
- , hetmet_pga_cancell
- , hetmet_pga_cancelr
- , hetmet_pga_uncancell
- , hetmet_pga_uncancelr
- , hetmet_pga_assoc
- , hetmet_pga_unassoc
- , hetmet_pga_copy
- , hetmet_pga_drop
- , hetmet_pga_swap
- , hetmet_pga_applyl
- , hetmet_pga_applyr
- , hetmet_pga_curryl
- , hetmet_pga_curryr
- , hetmet_pga_loopl
- , hetmet_pga_loopr
- ) }
+ , ds_hpc_info, modBreaks, junk)
+ }
; case mb_res of {
Nothing -> return (msgs, Nothing) ;
- Just (ds_ev_binds, all_prs, all_rules, vects0, ds_fords, ds_hpc_info, modBreaks
- , hetmet_brak, hetmet_esc
- , hetmet_flatten
- , hetmet_unflatten
- , hetmet_flattened_id
- , hetmet_PGArrow
- , hetmet_PGArrow_unit
- , hetmet_PGArrow_tensor
- , hetmet_PGArrow_exponent
- , hetmet_pga_id
- , hetmet_pga_comp
- , hetmet_pga_first
- , hetmet_pga_second
- , hetmet_pga_cancell
- , hetmet_pga_cancelr
- , hetmet_pga_uncancell
- , hetmet_pga_uncancelr
- , hetmet_pga_assoc
- , hetmet_pga_unassoc
- , hetmet_pga_copy
- , hetmet_pga_drop
- , hetmet_pga_swap
- , hetmet_pga_applyl
- , hetmet_pga_applyr
- , hetmet_pga_curryl
- , hetmet_pga_curryr
- , hetmet_pga_loopl
- , hetmet_pga_loopr
- ) -> do
+ Just (ds_ev_binds, all_prs, all_rules, vects0, ds_fords, ds_hpc_info, modBreaks, junk) -> do
{ -- Add export flags to bindings
keep_alive <- readIORef keep_var
-- You might think it doesn't matter, but the simplifier brings all top-level
-- things into the in-scope set before simplifying; so we get no unfolding for F#!
- ; (final_pgm', rules_for_imps') <- if dopt Opt_F_simpleopt_before_flatten dflags
- then simpleOptPgm dflags final_pgm rules_for_imps
- else return (final_pgm, rules_for_imps)
+ ; (final_pgm1, rules_for_imps1, ds_vects1) <- if dopt Opt_F_simpleopt_before_flatten dflags
+ then simpleOptPgm dflags final_pgm rules_for_imps vects0
+ else return (final_pgm, rules_for_imps, vects0)
- ; ds_binds <- if dopt Opt_F_coqpass dflags
+ ; ds_binds1 <- if dopt Opt_F_coqpass dflags
then do { us <- mkSplitUniqSupply '~'
; let do_flatten = dopt Opt_F_flatten dflags
; let do_skolemize = dopt Opt_F_skolemize dflags
- ; return (coqPassCoreToCore
- do_flatten
- do_skolemize
- hetmet_brak
- hetmet_esc
- hetmet_flatten
- hetmet_unflatten
- hetmet_flattened_id
- us
- final_pgm'
- hetmet_PGArrow
- hetmet_PGArrow_unit
- hetmet_PGArrow_tensor
- hetmet_PGArrow_exponent
- hetmet_pga_id
- hetmet_pga_comp
- hetmet_pga_first
- hetmet_pga_second
- hetmet_pga_cancell
- hetmet_pga_cancelr
- hetmet_pga_uncancell
- hetmet_pga_uncancelr
- hetmet_pga_assoc
- hetmet_pga_unassoc
- hetmet_pga_copy
- hetmet_pga_drop
- hetmet_pga_swap
- hetmet_pga_applyl
- hetmet_pga_applyr
- hetmet_pga_curryl
- hetmet_pga_curryr
- hetmet_pga_loopl
- hetmet_pga_loopr
+ ; (case junk of {
+ ( hetmet_brak ,
+ hetmet_esc ,
+ hetmet_flatten ,
+ hetmet_unflatten ,
+ hetmet_flattened_id ,
+ hetmet_PGArrow ,
+ hetmet_PGArrow_unit ,
+ hetmet_PGArrow_tensor ,
+ hetmet_PGArrow_exponent ,
+ hetmet_pga_id ,
+ hetmet_pga_comp ,
+ hetmet_pga_first ,
+ hetmet_pga_second ,
+ hetmet_pga_cancell ,
+ hetmet_pga_cancelr ,
+ hetmet_pga_uncancell ,
+ hetmet_pga_uncancelr ,
+ hetmet_pga_assoc ,
+ hetmet_pga_unassoc ,
+ hetmet_pga_copy ,
+ hetmet_pga_drop ,
+ hetmet_pga_swap ,
+ hetmet_pga_applyl ,
+ hetmet_pga_applyr ,
+ hetmet_pga_curryl ,
+ hetmet_pga_curryr ,
+ hetmet_pga_loopl ,
+ hetmet_pga_loopr ) ->
+ return (coqPassCoreToCore
+ do_flatten
+ do_skolemize
+ hetmet_brak
+ hetmet_esc
+ hetmet_flatten
+ hetmet_unflatten
+ hetmet_flattened_id
+ us
+ final_pgm1
+ hetmet_PGArrow
+ hetmet_PGArrow_unit
+ hetmet_PGArrow_tensor
+ hetmet_PGArrow_exponent
+ hetmet_pga_id
+ hetmet_pga_comp
+ hetmet_pga_first
+ hetmet_pga_second
+ hetmet_pga_cancell
+ hetmet_pga_cancelr
+ hetmet_pga_uncancell
+ hetmet_pga_uncancelr
+ hetmet_pga_assoc
+ hetmet_pga_unassoc
+ hetmet_pga_copy
+ hetmet_pga_drop
+ hetmet_pga_swap
+ hetmet_pga_applyl
+ hetmet_pga_applyr
+ hetmet_pga_curryl
+ hetmet_pga_curryr
+ hetmet_pga_loopl
+ hetmet_pga_loopr
)
+ }
+ )
}
else return final_pgm
- ; (ds_binds', ds_rules_for_imps) <- if dopt Opt_F_simpleopt_before_flatten dflags
- then return (ds_binds, rules_for_imps')
- else simpleOptPgm dflags ds_binds rules_for_imps'
+ ; (ds_binds2, ds_rules_for_imps2, ds_vects2) <- if dopt Opt_F_simpleopt_before_flatten dflags
+ then return (ds_binds1, rules_for_imps1, ds_vects1)
+ else simpleOptPgm dflags ds_binds1 rules_for_imps1 ds_vects1
-- The simpleOptPgm gets rid of type
-- bindings plus any stupid dead code
- ; dumpIfSet_dyn dflags Opt_D_dump_proofs "Coq Pass Output" $ text $ coqPassCoreToString ds_binds'
+ ; dumpIfSet_dyn dflags Opt_D_dump_proofs "Coq Pass Output" $ text $ coqPassCoreToString ds_binds1
- ; dumpIfSet_dyn dflags Opt_D_coqpass "After Coq Pass" (text $ showSDoc $ pprCoreBindings ds_binds')
+ ; dumpIfSet_dyn dflags Opt_D_coqpass "After Coq Pass" (text $ showSDoc $ pprCoreBindings ds_binds1)
- ; (ds_binds, ds_rules_for_imps, ds_vects)
- <- simpleOptPgm dflags final_pgm rules_for_imps vects0
+ ; (ds_binds3, ds_rules_for_imps3, ds_vects3)
+ <- simpleOptPgm dflags ds_binds2 ds_rules_for_imps2 ds_vects2
-- The simpleOptPgm gets rid of type
-- bindings plus any stupid dead code
- ; endPass dflags CoreDesugar ds_binds ds_rules_for_imps
+ ; endPass dflags CoreDesugar ds_binds3 ds_rules_for_imps3
; let used_names = mkUsedNames tcg_env
; deps <- mkDependencies tcg_env
mg_fam_insts = fam_insts,
mg_inst_env = inst_env,
mg_fam_inst_env = fam_inst_env,
- mg_rules = ds_rules_for_imps,
- mg_binds = ds_binds',
+ mg_rules = ds_rules_for_imps3,
+ mg_binds = ds_binds3,
mg_foreign = ds_fords,
mg_hpc_info = ds_hpc_info,
mg_modBreaks = modBreaks,
- mg_vect_decls = ds_vects,
+ mg_vect_decls = ds_vects2,
mg_vect_info = noVectInfo
}
; return (msgs, Just mod_guts)