diff options
| author | Hugo Herbelin | 2016-04-13 21:21:57 +0200 |
|---|---|---|
| committer | Hugo Herbelin | 2016-04-27 21:55:48 +0200 |
| commit | 5598db7882f111b1fe3aa22936679e06b7a2f673 (patch) | |
| tree | 004f07a6f330eebed1bef01d8e26022ce522b406 | |
| parent | d82c87e40a85be184ede1f9a2fde04dd8f48bb74 (diff) | |
Isolating and exporting a function for printing body of a recursive definition.
| -rw-r--r-- | printing/ppvernac.ml | 21 |
1 files changed, 10 insertions, 11 deletions
diff --git a/printing/ppvernac.ml b/printing/ppvernac.ml index 17926055e8..efdaa366bb 100644 --- a/printing/ppvernac.ml +++ b/printing/ppvernac.ml @@ -381,6 +381,14 @@ module Make | None -> mt () | Some pl -> str"@{" ++ prlist_with_sep spc pr_lident pl ++ str"}" + let pr_rec_definition ((((loc,id),pl),ro,bl,type_,def),ntn) = + let pr_pure_lconstr c = Flags.without_option Flags.beautify_file pr_lconstr c in + let annot = pr_guard_annot pr_lconstr_expr bl ro in + pr_id id ++ pr_univs pl ++ pr_binders_arg bl ++ annot + ++ pr_type_option (fun c -> spc() ++ pr_lconstr_expr c) type_ + ++ pr_opt (fun def -> str":=" ++ brk(1,2) ++ pr_pure_lconstr def) def + ++ prlist (pr_decl_notation pr_constr) ntn + let pr_statement head (idpl,(bl,c,guard)) = assert (not (Option.is_empty idpl)); let id, pl = Option.get idpl in @@ -789,19 +797,10 @@ module Make | Some Local -> "Local " | None | Some Global -> "" in - let pr_pure_lconstr c = - Flags.without_option Flags.beautify_file pr_lconstr c in - let pr_onerec = function - | (((loc,id),pl),ro,bl,type_,def),ntn -> - let annot = pr_guard_annot pr_lconstr_expr bl ro in - pr_id id ++ pr_univs pl ++ pr_binders_arg bl ++ annot - ++ pr_type_option (fun c -> spc() ++ pr_lconstr_expr c) type_ - ++ pr_opt (fun def -> str":=" ++ brk(1,2) ++ pr_pure_lconstr def) def ++ - prlist (pr_decl_notation pr_constr) ntn - in return ( hov 0 (str local ++ keyword "Fixpoint" ++ spc () ++ - prlist_with_sep (fun _ -> fnl () ++ keyword "with" ++ spc ()) pr_onerec recs) + prlist_with_sep (fun _ -> fnl () ++ keyword "with" + ++ spc ()) pr_rec_definition recs) ) | VernacCoFixpoint (local, corecs) -> |
