1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
|
(************************************************************************)
(* * The Coq Proof Assistant / The Coq Development Team *)
(* v * Copyright INRIA, CNRS and contributors *)
(* <O___,, * (see version control and CREDITS file for authors & dates) *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(* * (see LICENSE file for the text of the license) *)
(************************************************************************)
open Util
open Pp
(* Recursively puts `.v` files in the LoadPath *)
let build_stdlib_vo_path ~unix_path ~coq_path =
let open Loadpath in
{ unix_path; coq_path ; has_ml = false; implicit = true; recursive = true }
(* Note we don't use has_ml=true due to #12771 , we need to see if we
should just remove that option *)
let build_userlib_path ~unix_path =
let open Loadpath in
if Sys.file_exists unix_path then
let ml_path = System.all_subdirs ~unix_path |> List.map fst in
let vo_path =
{ unix_path
; coq_path = Libnames.default_root_prefix
; has_ml = false
; implicit = false
; recursive = true
} in
ml_path, [vo_path]
else [], []
let legacy_plugin_paths coredir =
let open Boot in
let unix_path = Path.relative coredir "plugins" in
(* BOOTCOQC doesn't pass -boot to coqc, so this is too strong!
Reinstate when moving to coq_dune *)
(* if not (Path.exists unix_path) then
* CErrors.user_err (Pp.str "Cannot find plugins directory"); *)
let unix_path = Path.to_string unix_path in
System.all_subdirs ~unix_path |> List.map fst
(* LoadPath for Coq user libraries *)
let init_load_path ~coqenv =
let open Loadpath in
let user_contrib = Boot.Env.user_contrib coqenv |> Boot.Path.to_string in
let xdg_dirs = Envars.xdg_dirs ~warn:(fun x -> Feedback.msg_warning (str x)) in
let coqpath = Envars.coqpath in
let coq_path = Names.DirPath.make [Libnames.coq_root] in
(* ML includes *)
let core_dir = Boot.Env.corelib coqenv in
(* EJGA: We can clean this up when we the build systems do send the
right -I for us. Dune already does this, not sure about Coq
Makefile / findlib setup *)
let plugins_dirs = legacy_plugin_paths core_dir in
(* EJGA: this needs clenaup, we must be deterministic *)
let meta_dir = if Boot.Env.Path.(exists (relative core_dir "META"))
then [Boot.Env.Path.(to_string (relative core_dir ".."))]
else []
in
let stdlib = Boot.Env.stdlib coqenv |> Boot.Path.to_string in
let contrib_ml, contrib_vo = build_userlib_path ~unix_path:user_contrib in
let misc_ml, misc_vo =
List.map (fun s -> build_userlib_path ~unix_path:s) (xdg_dirs @ coqpath) |> List.split in
let ml_loadpath = plugins_dirs @ meta_dir @ contrib_ml @ List.concat misc_ml in
let vo_loadpath =
(* current directory (not recursively!) *)
[ { unix_path = "."
; coq_path = Libnames.default_root_prefix
; implicit = false
; has_ml = true
; recursive = false
} ] @
(* then standard library *)
[build_stdlib_vo_path ~unix_path:stdlib ~coq_path] @
(* then user-contrib *)
contrib_vo @
(* then directories in XDG_DATA_DIRS and XDG_DATA_HOME and COQPATH *)
List.concat misc_vo
in
ml_loadpath, vo_loadpath
|