diff options
author | 2007-01-24 08:42:08 +0000 | |
---|---|---|
committer | 2007-01-24 08:42:08 +0000 | |
commit | f9b82ff1cf034f1a85a84c53a8dfc2efaa2b0913 (patch) | |
tree | 3b3abd346480b84057f0547704eb45e9fe4474d5 /library/library.ml | |
parent | e7e537bf26268f9ba00e6de31423c59078a99dd3 (diff) |
Correction bug #1333 (test non récursivité des dépendances en d'autres
"library" lors de la construction d'une "library" -- i.e. d'un .vo)
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@9524 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'library/library.ml')
-rw-r--r-- | library/library.ml | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/library/library.ml b/library/library.ml index 5cd69bc02..7e93db65e 100644 --- a/library/library.ml +++ b/library/library.ml @@ -591,6 +591,12 @@ let current_deps () = let current_reexports () = List.map (fun m -> m.library_name) !libraries_exports_list +let error_recursively_dependent_library dir = + errorlabstrm "" + (str "Unable to use logical name" ++ spc() ++ pr_dirpath dir ++ spc() ++ + str "to save current library" ++ spc() ++ str"because" ++ spc() ++ + str "it already depends on a library of this name.") + let save_library_to dir f = let cenv, seg = Declaremods.end_library dir in let md = { @@ -599,6 +605,8 @@ let save_library_to dir f = md_objects = seg; md_deps = current_deps (); md_imports = current_reexports () } in + if List.mem_assoc dir md.md_deps then + error_recursively_dependent_library dir; let (f',ch) = raw_extern_library f in try System.marshal_out ch md; |