Source file cache.ml

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
module Log = Dune_util.Log
open Stdune
module Key = Key
include Cache_intf

let promotion_to_string = function
  | Already_promoted { path; digest } ->
    Printf.sprintf "%s already promoted with digest %s"
      (Path.Local.to_string (Path.Build.local path))
      (Digest.to_string digest)
  | Promoted { path; digest } ->
    Printf.sprintf "%s promoted with digest %s"
      (Path.Local.to_string (Path.Build.local path))
      (Digest.to_string digest)

let make_caching (type t) (module Caching : Cache with type t = t) (cache : t) :
    (module Caching) =
  (module struct
    module Cache = Caching

    let cache = cache
  end)

let cachable = function
  | Unix.S_REG -> true
  | _ -> false

module Client = Client
module Local = Local
module Messages = Messages