Skip to content

Commit

Permalink
feat(engine/fstar): do not mark refinement type with unfold
Browse files Browse the repository at this point in the history
  • Loading branch information
W95Psp committed Apr 29, 2024
1 parent 6f6c25e commit 15e6ad7
Showing 1 changed file with 8 additions and 5 deletions.
13 changes: 8 additions & 5 deletions engine/backends/fstar/fstar_backend.ml
Original file line number Diff line number Diff line change
Expand Up @@ -914,18 +914,21 @@ struct
@@ F.AST.PatVar
(F.id @@ U.Concrete_ident_view.to_definition_name name, None, [])
in
let ty =
let ty, quals =
(* Adds a refinement if a refinement attribute is detected *)
match Attrs.associated_expr ~keep_last_args:1 Ensures e.attrs with
| Some { e = Closure { params = [ binder ]; body; _ }; _ } ->
let binder, _ =
U.Expect.pbinding_simple binder |> Option.value_exn
in
F.mk_refined (plocal_ident_str binder) (pty e.span ty) (fun ~x ->
pexpr body)
| _ -> pty e.span ty
let ty =
F.mk_refined (plocal_ident_str binder) (pty e.span ty)
(fun ~x -> pexpr body)
in
(ty, [])
| _ -> (pty e.span ty, [ F.AST.Unfold_for_unification_and_vcgen ])
in
F.decls ~quals:[ F.AST.Unfold_for_unification_and_vcgen ]
F.decls ~quals
@@ F.AST.TopLevelLet
( NoLetQualifier,
[
Expand Down

0 comments on commit 15e6ad7

Please sign in to comment.