Skip to content

Commit

Permalink
refactor: vlib rules clean up (ocaml#11104)
Browse files Browse the repository at this point in the history
Signed-off-by: Rudi Grinberg <me@rgrinberg.com>
  • Loading branch information
rgrinberg authored Nov 5, 2024
1 parent 5707bf0 commit efeb3d0
Showing 1 changed file with 16 additions and 17 deletions.
33 changes: 16 additions & 17 deletions src/dune_rules/virtual_rules.ml
Original file line number Diff line number Diff line change
Expand Up @@ -75,8 +75,7 @@ let impl sctx ~(lib : Library.t) ~scope =
| Some vlib ->
let info = Lib.info vlib in
let virtual_ =
let virtual_ = Lib_info.virtual_ info in
match virtual_ with
match Lib_info.virtual_ info with
| Some v -> v
| None ->
User_error.raise
Expand Down Expand Up @@ -104,28 +103,28 @@ let impl sctx ~(lib : Library.t) ~scope =
let db = Scope.libs scope in
let* preprocess =
(* TODO wrong, this should be delayed *)
Resolve.Memo.read_memo
(Preprocess.Per_module.with_instrumentation
lib.buildable.preprocess
~instrumentation_backend:(Lib.DB.instrumentation_backend db))
in
let pp_spec =
Staged.unstage (Pp_spec.pped_modules_map preprocess ocaml.version)
Preprocess.Per_module.with_instrumentation
lib.buildable.preprocess
~instrumentation_backend:(Lib.DB.instrumentation_backend db)
|> Resolve.Memo.read_memo
in
Dir_contents.ocaml dir_contents
>>= Ml_sources.modules
~libs:db
~for_:(Library (Lib_info.lib_id info |> Lib_id.to_local_exn))
>>= Modules.map_user_written ~f:(fun m -> Memo.return (pp_spec m))
>>=
let pp_spec =
Staged.unstage (Pp_spec.pped_modules_map preprocess ocaml.version)
in
Modules.map_user_written ~f:(fun m -> Memo.return (pp_spec m))
in
let+ foreign_objects =
let ext_obj = ocaml.lib_config.ext_obj in
let dir = Obj_dir.obj_dir (Lib.Local.obj_dir vlib) in
let+ foreign_sources = Dir_contents.foreign_sources dir_contents in
foreign_sources
|> Foreign_sources.for_lib ~name
|> Foreign.Sources.object_files ~ext_obj ~dir
|> List.map ~f:Path.build
Dir_contents.foreign_sources dir_contents
>>| Foreign_sources.for_lib ~name
>>| (let ext_obj = ocaml.lib_config.ext_obj in
let dir = Obj_dir.obj_dir (Lib.Local.obj_dir vlib) in
Foreign.Sources.object_files ~ext_obj ~dir)
>>| List.map ~f:Path.build
in
modules, foreign_objects
in
Expand Down

0 comments on commit efeb3d0

Please sign in to comment.