B00_ocaml.CobjCompiled object information.
val archive_ext_of_code : Conf.code -> B00_std.Fpath.extarchive_ext_of_code c is .cma or .cmxa according to c.
val object_ext_of_code : Conf.code -> B00_std.Fpath.extobject_ext_of_code c is .cmo or .cmx according to c.
The type for compilation objects. This can represent one of a cmi, cmti, cmo, cmx, cmt, cma or cmxa file.
val file : t -> B00_std.Fpath.tfile c is the compilation object file path.
val defs : t -> Mod.Ref.Set.tdefs c are the modules defined by the compilation object. If there's more than one you are looking an archive.
val deps : t -> Mod.Ref.Set.tdeps c is the set of modules needed by defs c. More precisely these are the module interfaces imported by c. See also link_deps.
val link_deps : t -> Mod.Ref.Set.tlink_deps c is the set of modules needed to link defs c.
Note. Unclear whether this is the right data. Basically these are the module references that of deps whose name is in the required globals (bytecode) or imported implementations (native code) as reported by ocamlobjinfo. Initially we'd use deps for link dependencies but it turns out that this may break on certain install structures. It's unclear whether we need both deps and link_deps and/or if that's the correct information.
val pp : t B00_std.Fmt.tpp formats an compilation object.
val sort : ?deps:(t -> Mod.Ref.Set.t) -> t list -> t list * Mod.Ref.Set.tsort ~deps cobjs is cobjs stable sorted in dependency order according to deps (defaults to link_deps), tupled with external dependencies needed by cobjs.
val write : B00.Memo.t -> cobjs:B00_std.Fpath.t list -> o:B00_std.Fpath.t -> unitwrite m ~cobjs o writes information about the compilation cobjs to o.
val read : B00.Memo.t -> B00_std.Fpath.t -> t list B00_std.Fut.tread m file has the cobjs of a write to file.
val of_string : ?file:B00_std.Fpath.t -> string -> (t list, string) resultof_string ~file data parses compilation object information from data as output by Tool.ocamlobjinfo assuming it was read from file (defaults to B00_std.Os.File.dash).