summary refs log tree commit diff
path: root/gnu/packages/patches/coq-fix-envvars.patch
diff options
context:
space:
mode:
Diffstat (limited to 'gnu/packages/patches/coq-fix-envvars.patch')
-rw-r--r--gnu/packages/patches/coq-fix-envvars.patch148
1 files changed, 31 insertions, 117 deletions
diff --git a/gnu/packages/patches/coq-fix-envvars.patch b/gnu/packages/patches/coq-fix-envvars.patch
index deecf5ce74..6c48224c64 100644
--- a/gnu/packages/patches/coq-fix-envvars.patch
+++ b/gnu/packages/patches/coq-fix-envvars.patch
@@ -1,63 +1,44 @@
-From ebe09fcac72b21d17c4e8fe6edc1b6076a4ae97c Mon Sep 17 00:00:00 2001
+From 0e76cda958a4d3e4bcbb96e171c26b6b3478c6c2 Mon Sep 17 00:00:00 2001
 From: Julien Lepiller <julien@lepiller.eu>
-Date: Sun, 21 Nov 2021 00:38:03 +0100
+Date: Thu, 10 Feb 2022 16:44:10 +0100
 Subject: [PATCH] Fix environment variable usage.
 
 ---
- checker/checker.ml      |  2 ++
- lib/envars.ml           | 26 ++++++++++++++++----------
- sysinit/coqargs.ml      |  3 ++-
- sysinit/coqloadpath.ml  |  3 ++-
- sysinit/coqloadpath.mli |  2 +-
- tools/coqdep.ml         |  2 +-
- 6 files changed, 24 insertions(+), 14 deletions(-)
+ boot/env.ml | 26 +++++++++++++++++++-------
+ 1 file changed, 19 insertions(+), 7 deletions(-)
 
-diff --git a/checker/checker.ml b/checker/checker.ml
-index f55ed9e8d6..3b797729ed 100644
---- a/checker/checker.ml
-+++ b/checker/checker.ml
-@@ -104,6 +104,7 @@ let set_include d p =
- (* Initializes the LoadPath *)
- let init_load_path () =
-   let coqlib = Envars.coqlib () in
-+  let coqcorelib = Envars.coqcorelib () in
-   let user_contrib = coqlib/"user-contrib" in
-   let xdg_dirs = Envars.xdg_dirs in
-   let coqpath = Envars.coqpath in
-@@ -111,6 +112,7 @@ let init_load_path () =
-     CPath.choose_existing
-       [ CPath.make [ coqlib ; "plugins" ]
-       ; CPath.make [ coqlib ; ".."; "coq-core"; "plugins" ]
-+      ; CPath.make [ coqcorelib ; "plugins" ]
-       ] |> function
-     | None ->
-       CErrors.user_err (Pp.str "Cannot find plugins directory")
-diff --git a/lib/envars.ml b/lib/envars.ml
-index 750bd60e71..c7affbd437 100644
---- a/lib/envars.ml
-+++ b/lib/envars.ml
-@@ -127,15 +127,21 @@ let check_file_else ~dir ~file oth =
- let guess_coqlib fail =
-   getenv_else "COQLIB" (fun () ->
+diff --git a/boot/env.ml b/boot/env.ml
+index e8521e7..d834a3a 100644
+--- a/boot/env.ml
++++ b/boot/env.ml
+@@ -32,17 +32,29 @@ let fail_msg =
+ 
+ let fail s = Format.eprintf "%s@\n%!" fail_msg; exit 1
+ 
++let path_to_list p =
++  let sep = if String.equal Sys.os_type "Win32" then ';' else ':' in
++    String.split_on_char sep p
++
+ (* This code needs to be refactored, for now it is just what used to be in envvars  *)
+ let guess_coqlib () =
+   Util.getenv_else "COQLIB" (fun () ->
    let prelude = "theories/Init/Prelude.vo" in
--  check_file_else ~dir:Coq_config.coqlibsuffix ~file:prelude
+-  Util.check_file_else
+-    ~dir:Coq_config.coqlibsuffix
+-    ~file:prelude
 -    (fun () ->
--      if Sys.file_exists (Coq_config.coqlib / prelude)
+-      if Sys.file_exists (Filename.concat Coq_config.coqlib prelude)
 -      then Coq_config.coqlib
--      else
--        fail "cannot guess a path for Coq libraries; please use -coqlib option \
--              or ensure you have installed the package containing Coq's stdlib (coq-stdlib in OPAM) \
--              If you intend to use Coq without a standard library, the -boot -noinit options must be used.")
--  )
-+  let coqlibpath = getenv_else "COQLIBPATH" (fun () -> Coq_config.coqlibsuffix) in
+-      else fail ()))
++  let coqlibpath = Util.getenv_else "COQLIBPATH" (fun () -> Coq_config.coqlibsuffix) in
 +  let paths = path_to_list coqlibpath in
 +  let valid_paths =
 +    List.filter
-+      (fun dir -> (check_file_else ~dir:dir ~file:prelude (fun () -> "")) <> "")
++      (fun dir -> (Util.check_file_else ~dir:dir ~file:prelude (fun () -> "")) <> "")
 +      paths in
 +  match valid_paths with
 +  | [] ->
-+    if Sys.file_exists (Coq_config.coqlib / prelude)
++    if Sys.file_exists (Filename.concat Coq_config.coqlib prelude)
 +    then Coq_config.coqlib
 +    else
 +      fail "cannot guess a path for Coq libraries; please use -coqlib option \
@@ -65,75 +46,8 @@ index 750bd60e71..c7affbd437 100644
 +            If you intend to use Coq without a standard library, the -boot -noinit options must be used."
 +  | p::_ -> p)
  
- let coqlib_ref : string option ref = ref None
- let set_user_coqlib path = coqlib_ref := Some path
-@@ -208,7 +214,7 @@ let xdg_dirs ~warn =
- let print_config ?(prefix_var_name="") f coq_src_subdirs =
-   let open Printf in
-   fprintf f "%sCOQLIB=%s/\n" prefix_var_name (coqlib ());
--  fprintf f "%sCOQCORELIB=%s/\n" prefix_var_name (coqlib () / "../coq-core/");
-+  fprintf f "%sCOQCORELIB=%s/\n" prefix_var_name (coqcorelib ());
-   fprintf f "%sDOCDIR=%s/\n" prefix_var_name (docdir ());
-   fprintf f "%sOCAMLFIND=%s\n" prefix_var_name (ocamlfind ());
-   fprintf f "%sCAMLFLAGS=%s\n" prefix_var_name Coq_config.caml_flags;
-diff --git a/sysinit/coqargs.ml b/sysinit/coqargs.ml
-index 00f70a5fea..8325623a63 100644
---- a/sysinit/coqargs.ml
-+++ b/sysinit/coqargs.ml
-@@ -453,7 +453,8 @@ let build_load_path opts =
-     if opts.pre.boot then [],[]
-     else
-       let coqlib = Envars.coqlib () in
--      Coqloadpath.init_load_path ~coqlib in
-+      let coqcorelib = Envars.coqcorelib () in
-+      Coqloadpath.init_load_path ~coqlib ~coqcorelib in
-   ml_path @ opts.pre.ml_includes ,
-   vo_path @ opts.pre.vo_includes
- 
-diff --git a/sysinit/coqloadpath.ml b/sysinit/coqloadpath.ml
-index 95ae5da3de..a58cfe6928 100644
---- a/sysinit/coqloadpath.ml
-+++ b/sysinit/coqloadpath.ml
-@@ -35,7 +35,7 @@ let build_userlib_path ~unix_path =
-   else [], []
- 
- (* LoadPath for Coq user libraries *)
--let init_load_path ~coqlib =
-+let init_load_path ~coqlib ~coqcorelib =
- 
-   let open Loadpath in
-   let user_contrib = coqlib/"user-contrib" in
-@@ -50,6 +50,7 @@ let init_load_path ~coqlib =
-     CPath.choose_existing
-       [ CPath.make [ coqlib ; "plugins" ]
-       ; CPath.make [ coqlib ; ".."; "coq-core"; "plugins" ]
-+      ; CPath.make [ coqcorelib ; "plugins" ]
-       ] |> function
-     | None ->
-       CErrors.user_err (Pp.str "Cannot find plugins directory")
-diff --git a/sysinit/coqloadpath.mli b/sysinit/coqloadpath.mli
-index d853e9ea54..43c6dfa134 100644
---- a/sysinit/coqloadpath.mli
-+++ b/sysinit/coqloadpath.mli
-@@ -12,5 +12,5 @@
-    includes (in-order) Coq's standard library, Coq's [user-contrib]
-    folder, and directories specified in [COQPATH] and [XDG_DIRS] *)
- val init_load_path
--  : coqlib:CUnix.physical_path
-+  : coqlib:CUnix.physical_path -> coqcorelib:CUnix.physical_path
-   -> CUnix.physical_path list * Loadpath.vo_path list
-diff --git a/tools/coqdep.ml b/tools/coqdep.ml
-index c1c87993e1..6c78e10866 100644
---- a/tools/coqdep.ml
-+++ b/tools/coqdep.ml
-@@ -33,7 +33,7 @@ let coqdep () =
-     let coqlib = Envars.coqlib () in
-     let coq_plugins_dir = Filename.concat (Envars.coqcorelib ()) "plugins" in
-     if not (Sys.file_exists coq_plugins_dir) then
--      CErrors.user_err Pp.(str "coqdep: cannot find plugins directory for coqlib: " ++ str coqlib ++ fnl ());
-+      CErrors.user_err Pp.(str "coqdep: cannot find plugins directory " ++ str coq_plugins_dir ++ str " for coqlib: " ++ str coqlib ++ fnl ());
-     CD.add_rec_dir_import CD.add_coqlib_known (coqlib//"theories") ["Coq"];
-     CD.add_rec_dir_import CD.add_coqlib_known (coq_plugins_dir) ["Coq"];
-     let user = coqlib//"user-contrib" in
+ (* Build layout uses coqlib = coqcorelib *)
+ let guess_coqcorelib lib =
 -- 
-2.33.1
+2.34.0
+