X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=compiler%2FcoreSyn%2FPprExternalCore.lhs;h=5303b0d1b68ffed31265e510bf9547e3c116a907;hp=fb4fc45ecf4849f533dcbaf721b16ddf86c30ba2;hb=fdf8656855d26105ff36bdd24d41827b05037b91;hpb=b0045fdd4404f3ac2ddacad8c39a017f01f8ff6b diff --git a/compiler/coreSyn/PprExternalCore.lhs b/compiler/coreSyn/PprExternalCore.lhs index fb4fc45..5303b0d 100644 --- a/compiler/coreSyn/PprExternalCore.lhs +++ b/compiler/coreSyn/PprExternalCore.lhs @@ -5,12 +5,12 @@ \begin{code} module PprExternalCore () where -import ExternalCore import Encoding +import ExternalCore import Pretty -import Char - +import Data.Char +import Data.Ratio instance Show Module where showsPrec _ m = shows (pmodule m) @@ -54,23 +54,10 @@ ptdef (Data tcon tbinds cdefs) = (text "%data" <+> pqname tcon <+> (hsep (map ptbind tbinds)) <+> char '=') $$ indent (braces ((vcat (punctuate (char ';') (map pcdef cdefs))))) -ptdef (Newtype tcon tbinds (coercion,tbs,k) rep) = --- TODO: I think this is kind of redundant now. --- Here we take apart the newtype tycon in order to get the newtype coercion, --- which needs to be represented in the External Core file because it's not --- straightforward to derive its definition from the newtype declaration alone. --- At the same time, we need the newtype decl to declare the tycon itself. --- Sigh. - text "%newtype" <+> pqname tcon <+> (hsep (map ptbind tbinds)) - $$ indent (axiomclause $$ repclause) - where axiomclause = char '^' - <+> parens (pqname coercion <+> (hsep (map ptbind tbs)) - <+> text "::" - <+> pkind k) - repclause = case rep of - Just ty -> char '=' <+> pty ty - Nothing -> empty - +ptdef (Newtype tcon coercion tbinds rep) = + text "%newtype" <+> pqname tcon <+> pqname coercion + <+> (hsep (map ptbind tbinds)) $$ indent repclause + where repclause = char '=' <+> pty rep pcdef :: Cdef -> Doc pcdef (Constr dcon tbinds tys) = @@ -113,6 +100,16 @@ pbty t = paty t pty (Tapp(Tapp(Tcon tc) t1) t2) | tc == tcArrow = fsep [pbty t1, text "->",pty t2] pty (Tforall tb t) = text "%forall" <+> pforall [tb] t +pty (TransCoercion t1 t2) = + sep [text "%trans", paty t1, paty t2] +pty (SymCoercion t) = + sep [text "%sym", paty t] +pty (UnsafeCoercion t1 t2) = + sep [text "%unsafe", paty t1, paty t2] +pty (NthCoercion n t) = + sep [text "%nth", int n, paty t] +pty (InstCoercion t1 t2) = + sep [text "%inst", paty t1, paty t2] pty t = pbty t pappty :: Ty -> [Ty] -> Doc @@ -190,9 +187,12 @@ palt (Adefault e) = plit :: Lit -> Doc plit (Lint i t) = parens (integer i <> text "::" <> pty t) --- we use (text (show r)) because "(rational r)" was printing out things --- like "2.0e-2" (which isn't External Core) -plit (Lrational r t) = parens (text (show r) <> text "::" <> pty t) +-- we use (text (show (numerator r))) (and the same for denominator) +-- because "(rational r)" was printing out things like "2.0e-2" (which +-- isn't External Core), and (text (show r)) was printing out things +-- like "((-1)/5)" which isn't either (it should be "(-1/5)"). +plit (Lrational r t) = parens (text (show (numerator r)) <+> char '%' + <+> text (show (denominator r)) <> text "::" <> pty t) plit (Lchar c t) = parens (text ("\'" ++ escape [c] ++ "\'") <> text "::" <> pty t) plit (Lstring s t) = parens (pstring s <> text "::" <> pty t)