diff options
author | Pepe Iborra <mnislaih@gmail.com> | 2007-12-02 12:54:00 +0000 |
---|---|---|
committer | Pepe Iborra <mnislaih@gmail.com> | 2007-12-02 12:54:00 +0000 |
commit | 7f474b779449109760d133eef5aba0aa3c38474a (patch) | |
tree | 32533bfd3a7692ca1adc5b75b01097af2780f92e | |
parent | 5a99cd502b29503578bc6a227bf80f2db9742e79 (diff) | |
download | haskell-7f474b779449109760d133eef5aba0aa3c38474a.tar.gz |
refactoring only
-rw-r--r-- | compiler/ghci/Debugger.hs | 2 | ||||
-rw-r--r-- | compiler/ghci/RtClosureInspect.hs | 18 | ||||
-rw-r--r-- | compiler/main/InteractiveEval.hs | 2 |
3 files changed, 12 insertions, 10 deletions
diff --git a/compiler/ghci/Debugger.hs b/compiler/ghci/Debugger.hs index 5ae7db8caa..1b1b2c9025 100644 --- a/compiler/ghci/Debugger.hs +++ b/compiler/ghci/Debugger.hs @@ -79,7 +79,7 @@ pprintClosureCommand session bindThings force str = do -- Then, we extract a substitution, -- mapping the old tyvars to the reconstructed types. let Just reconstructed_type = termType term - subst = computeRTTIsubst (idType id) (reconstructed_type) + subst = unifyRTTI (idType id) (reconstructed_type) return (term',subst) tidyTermTyVars :: Session -> Term -> IO Term diff --git a/compiler/ghci/RtClosureInspect.hs b/compiler/ghci/RtClosureInspect.hs index dae9260db0..4a481f3ecd 100644 --- a/compiler/ghci/RtClosureInspect.hs +++ b/compiler/ghci/RtClosureInspect.hs @@ -30,7 +30,7 @@ module RtClosureInspect( termTyVars, -- unsafeDeepSeq, cvReconstructType, - computeRTTIsubst, + unifyRTTI, sigmaType, Closure(..), getClosureData, @@ -141,7 +141,8 @@ isFullyEvaluatedTerm NewtypeWrap{wrapped_term=t} = isFullyEvaluatedTerm t isFullyEvaluatedTerm _ = False instance Outputable (Term) where - ppr = head . cPprTerm cPprTermBase + ppr t | Just doc <- cPprTerm cPprTermBase t = doc + | otherwise = panic "Outputable Term instance" ------------------------------------------------------------------------- -- Runtime Closure Datatype and functions for retrieving closure related stuff @@ -327,8 +328,9 @@ type Precedence = Int type TermPrinter = Precedence -> Term -> SDoc type TermPrinterM m = Precedence -> Term -> m SDoc -app_prec,cons_prec ::Int -app_prec = 10 +app_prec,cons_prec, max_prec ::Int +max_prec = 10 +app_prec = max_prec cons_prec = 5 -- TODO Extract this info from GHC itself pprTerm :: TermPrinter -> TermPrinter @@ -373,7 +375,7 @@ pprNewtypeWrap y p NewtypeWrap{ty=ty, wrapped_term=t} | Just (tc,_) <- splitNewTyConApp_maybe ty , ASSERT(isNewTyCon tc) True , Just new_dc <- maybeTyConSingleCon tc = do - real_term <- y 10 t + real_term <- y max_prec t return$ cparen (p >= app_prec) (ppr new_dc <+> real_term) pprNewtypeWrap _ _ _ = panic "pprNewtypeWrap" @@ -440,7 +442,7 @@ cPprTermBase y = coerceShow f _p = return . text . show . f . unsafeCoerce# . val - --NOTE pprinting of list terms is not lazy + --Note pprinting of list terms is not lazy doList p h t = do let elems = h : getListTerms t isConsLast = termType(last elems) /= termType h @@ -740,8 +742,8 @@ cvReconstructType hsc_env max_depth mb_ty hval = runTR_maybe hsc_env $ do -- is that the former are _not_ polymorphic, thus polymorphism must -- be stripped. Syntactically, forall's must be stripped. -- We also remove predicates. -computeRTTIsubst :: Type -> Type -> TvSubst -computeRTTIsubst ty rtti_ty = +unifyRTTI :: Type -> Type -> TvSubst +unifyRTTI ty rtti_ty = case mb_subst of Just subst -> subst Nothing -> pprPanic "Failed to compute a RTTI substitution" diff --git a/compiler/main/InteractiveEval.hs b/compiler/main/InteractiveEval.hs index ace2a7f410..79a1056da9 100644 --- a/compiler/main/InteractiveEval.hs +++ b/compiler/main/InteractiveEval.hs @@ -610,7 +610,7 @@ rttiEnvironment hsc_env@HscEnv{hsc_IC=ic} = do tys <- reconstructType hsc_env 10 `mapM` incompletelyTypedIds -- map termType `fmap` (obtainTerm hsc_env False `mapM` incompletelyTypedIds) - let substs = [computeRTTIsubst ty ty' + let substs = [unifyRTTI ty ty' | (ty, Just ty') <- zip (map idType incompletelyTypedIds) tys] ic' = foldr (flip substInteractiveContext) ic (map skolemiseSubst substs) |