Skip to content

Commit

Permalink
Rename trait methods in bundles for all backends, but include them on…
Browse files Browse the repository at this point in the history
…ly for fstar (hack).
  • Loading branch information
maximebuyse committed Jan 23, 2025
1 parent 2b8f60c commit b6933c1
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 23 deletions.
3 changes: 3 additions & 0 deletions engine/backends/fstar/fstar_backend.ml
Original file line number Diff line number Diff line change
Expand Up @@ -1851,6 +1851,9 @@ let apply_phases (bo : BackendOptions.t) (items : Ast.Rust.item list) :
(* else *)
items
in
(* This is a hack that should be removed
(see https://github.com/hacspec/hax/issues/1078) *)
Dependencies.includes_for_bundled_trait_methods := true;
let items =
TransformToInputLanguage.ditems items
|> List.map ~f:unsize_as_identity
Expand Down
28 changes: 22 additions & 6 deletions engine/lib/dependencies.ml
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
open! Prelude

(** This is a hack that should be removed
(see https://github.com/hacspec/hax/issues/1078) *)
let includes_for_bundled_trait_methods = ref false

module Make (F : Features.T) = struct
module AST = Ast.Make (F)
module U = Ast_utils.Make (F)
Expand Down Expand Up @@ -455,7 +459,8 @@ module Make (F : Features.T) = struct
( name,
Concrete_ident.Create.move_under ~new_parent:new_name name
)))
| Some { v = Trait { items; _ }; _ } ->
| Some { v = Trait { items; _ }; _ }
when !includes_for_bundled_trait_methods ->
List.map items ~f:(fun { ti_ident; _ } ->
( ti_ident,
Concrete_ident.Create.move_under ~new_parent:new_name ti_ident
Expand All @@ -465,11 +470,22 @@ module Make (F : Features.T) = struct
let variant_and_constructors_renamings =
List.concat_map ~f:variants_renamings renamings
|> List.concat_map ~f:(fun (old_name, new_name) ->
[
(old_name, new_name);
( Concrete_ident.Create.constructor old_name,
Concrete_ident.Create.constructor new_name );
])
let trait_methods_renamings =
match from_ident old_name with
| Some { v = Trait { items; _ }; _ }
when not !includes_for_bundled_trait_methods ->
List.map items ~f:(fun { ti_ident; _ } ->
( ti_ident,
Concrete_ident.Create.move_under ~new_parent:new_name
ti_ident ))
| _ -> []
in
trait_methods_renamings
@ [
(old_name, new_name);
( Concrete_ident.Create.constructor old_name,
Concrete_ident.Create.constructor new_name );
])
in
let renamings =
match
Expand Down
4 changes: 4 additions & 0 deletions engine/lib/dependencies.mli
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,7 @@ module Make (F : Features.T) : sig
val filter_by_inclusion_clauses :
Types.inclusion_clause list -> AST.item list -> AST.item list
end

val includes_for_bundled_trait_methods : bool ref
(** This is a hack that should be removed
(see https://github.com/hacspec/hax/issues/1078) *)
Original file line number Diff line number Diff line change
Expand Up @@ -259,18 +259,8 @@ include Cyclic_modules.M1.Cyclic_bundle_892895908 {d as d}

include Cyclic_modules.M1.Cyclic_bundle_892895908 {b as b}
'''
"Cyclic_modules.Moved_trait.Nested.fst" = '''
module Cyclic_modules.Moved_trait.Nested
#set-options "--fuel 0 --ifuel 1 --z3rlimit 15"
open Core
open FStar.Mul

include Cyclic_modules.Moved_trait.Rec_bundle_963167032 {t_St as t_St}

include Cyclic_modules.Moved_trait.Rec_bundle_963167032 {g as g}
'''
"Cyclic_modules.Moved_trait.Rec_bundle_963167032.fst" = '''
module Cyclic_modules.Moved_trait.Rec_bundle_963167032
"Cyclic_modules.Moved_trait.Cyclic_bundle_202498800.fst" = '''
module Cyclic_modules.Moved_trait.Cyclic_bundle_202498800
#set-options "--fuel 0 --ifuel 1 --z3rlimit 15"
open Core
open FStar.Mul
Expand All @@ -293,21 +283,31 @@ let impl: v_Tr t_St =

let g (x: t_St) : Prims.unit = f_f #t_St #FStar.Tactics.Typeclasses.solve x
'''
"Cyclic_modules.Moved_trait.Nested.fst" = '''
module Cyclic_modules.Moved_trait.Nested
#set-options "--fuel 0 --ifuel 1 --z3rlimit 15"
open Core
open FStar.Mul

include Cyclic_modules.Moved_trait.Cyclic_bundle_202498800 {t_St as t_St}

include Cyclic_modules.Moved_trait.Cyclic_bundle_202498800 {g as g}
'''
"Cyclic_modules.Moved_trait.fst" = '''
module Cyclic_modules.Moved_trait
#set-options "--fuel 0 --ifuel 1 --z3rlimit 15"
open Core
open FStar.Mul

include Cyclic_modules.Moved_trait.Rec_bundle_963167032 {v_Tr as v_Tr}
include Cyclic_modules.Moved_trait.Cyclic_bundle_202498800 {v_Tr as v_Tr}

include Cyclic_modules.Moved_trait.Rec_bundle_963167032 {f_f_pre as f_f_pre}
include Cyclic_modules.Moved_trait.Cyclic_bundle_202498800 {f_f_pre as f_f_pre}

include Cyclic_modules.Moved_trait.Rec_bundle_963167032 {f_f_post as f_f_post}
include Cyclic_modules.Moved_trait.Cyclic_bundle_202498800 {f_f_post as f_f_post}

include Cyclic_modules.Moved_trait.Rec_bundle_963167032 {f_f as f_f}
include Cyclic_modules.Moved_trait.Cyclic_bundle_202498800 {f_f as f_f}

include Cyclic_modules.Moved_trait.Rec_bundle_963167032 {impl as impl}
include Cyclic_modules.Moved_trait.Cyclic_bundle_202498800 {impl as impl}
'''
"Cyclic_modules.Rec.fst" = '''
module Cyclic_modules.Rec
Expand Down

0 comments on commit b6933c1

Please sign in to comment.