diff options
author | letouzey <letouzey@85f007b7-540e-0410-9357-904b9bb8a0f7> | 2002-07-24 14:18:57 +0000 |
---|---|---|
committer | letouzey <letouzey@85f007b7-540e-0410-9357-904b9bb8a0f7> | 2002-07-24 14:18:57 +0000 |
commit | 9d62331f8bc221c5d85616b784714ee57376e6b9 (patch) | |
tree | 95419dcb8821629a7760e4548432f23f3c73c71c /contrib/extraction/haskell.ml | |
parent | bfac670c83aae51471696b57bf58d86a425ca2f0 (diff) |
reparation d'un bug (dummy_lams -> anonym_lams) + chgmt structutr d'un ml_type
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@2913 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'contrib/extraction/haskell.ml')
-rw-r--r-- | contrib/extraction/haskell.ml | 20 |
1 files changed, 7 insertions, 13 deletions
diff --git a/contrib/extraction/haskell.ml b/contrib/extraction/haskell.ml index 877961018..286747c6f 100644 --- a/contrib/extraction/haskell.ml +++ b/contrib/extraction/haskell.ml @@ -70,22 +70,16 @@ let empty_env () = [], P.globals() let rec pp_type par vl t = let rec pp_rec par = function | Tvar i -> (try pr_id (List.nth vl (pred i)) with _ -> (str "a" ++ int i)) - | Tapp l -> - (match collapse_type_app l with - | [] -> assert false - | [t] -> pp_rec par t - | t::l -> - (open_par par ++ - pp_rec false t ++ spc () ++ - prlist_with_sep (fun () -> (spc ())) (pp_type true vl) l ++ - close_par par)) + | Tglob (r,[]) -> pp_type_global r + | Tglob (r,l) -> + open_par par ++ pp_type_global r ++ spc () ++ + prlist_with_sep spc (pp_type true vl) l ++ close_par par | Tarr (t1,t2) -> - (open_par par ++ pp_rec true t1 ++ spc () ++ str "->" ++ spc () ++ - pp_rec false t2 ++ close_par par) - | Tglob r -> pp_type_global r + open_par par ++ pp_rec true t1 ++ spc () ++ str "->" ++ spc () ++ + pp_rec false t2 ++ close_par par | Tdummy -> str "()" | Tunknown -> str "()" - in + in hov 0 (pp_rec par t) (*s Pretty-printing of expressions. [par] indicates whether |