From 93815730c4d9b42ae0bf4bac051de18dec9c2a86 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicol=C3=A1s=20Ojeda=20B=C3=A4r?= Date: Sat, 4 Feb 2023 15:56:12 +0100 Subject: [PATCH] Unix.link: catch EMLINK also on Windows (#6993) --- CHANGES.md | 2 ++ src/dune_cache/local.ml | 5 ++++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/CHANGES.md b/CHANGES.md index 416e362e19a..58325a5e82e 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -114,6 +114,8 @@ Unreleased - Fix dependency cycle when installing files to the bin section with `glob_files` (#6764, fixes #6708, @gridbugs) +- Handle "Too many links" errors when using Dune cache on Windows (#6993, @nojb) + 3.6.2 (2022-12-21) ------------------ diff --git a/src/dune_cache/local.ml b/src/dune_cache/local.ml index 6e9aeab14af..d7cbbd0dd3f 100644 --- a/src/dune_cache/local.ml +++ b/src/dune_cache/local.ml @@ -59,7 +59,10 @@ end hard links on [$file] will be allowed, triggering the [EMLINK] code path. *) let link_even_if_there_are_too_many_links_already ~src ~dst = try Path.link src dst - with Unix.Unix_error (Unix.EMLINK, _, _) -> + with + | Unix.Unix_error (Unix.EMLINK, _, _) + | Unix.Unix_error (Unix.EUNKNOWNERR -1442, _, _) (* Needed for OCaml < 5.1 *) + -> Temp.with_temp_file ~dir:temp_dir ~prefix:"dune" ~suffix:"copy" ~f:(function | Error e -> raise e | Ok temp_file ->