From 1b9e19381744d94c722adcd73186432fccbcb216 Mon Sep 17 00:00:00 2001 From: Son Ho Date: Thu, 3 Feb 2022 21:28:17 +0100 Subject: Improve the extraction of `if ... then ... else ...` --- src/ExtractToFStar.ml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/ExtractToFStar.ml b/src/ExtractToFStar.ml index 60bc472d..3a5d2c7a 100644 --- a/src/ExtractToFStar.ml +++ b/src/ExtractToFStar.ml @@ -773,16 +773,20 @@ let rec extract_texpression (ctx : extraction_ctx) (fmt : F.formatter) (* Extract the branches *) let extract_branch (is_then : bool) (e_branch : texpression) : unit = F.pp_print_space fmt (); - (* Open a box for the branch *) + (* Open a box for the then/else+branch *) F.pp_open_hovbox fmt ctx.indent_incr; let then_or_else = if is_then then "then" else "else" in F.pp_print_string fmt then_or_else; F.pp_print_space fmt (); + (* Open a box for the branch *) + F.pp_open_hvbox fmt 0; let parenth = PureUtils.expression_requires_parentheses e_branch in if parenth then F.pp_print_string fmt "("; extract_texpression ctx fmt false e_branch; if parenth then F.pp_print_string fmt ")"; (* Close the box for the branch *) + F.pp_close_box fmt (); + (* Close the box for the then/else+branch *) F.pp_close_box fmt () in extract_branch true e_then; -- cgit v1.2.3