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
type t = Fpath.t [@@deriving eq, ord, show]
let hash p = Hashtbl.hash (Fpath.to_string p)
let pretty () p = GoblintCil.Pretty.text (Fpath.to_string p)
let to_yojson p = `String (Fpath.to_string p)
let of_yojson = function
| `String s ->
Fpath.of_string s
|> Result.map_error (fun (`Msg m) ->
"GobFpath.of_yojson: " ^ m
)
| _ ->
Error "GobFpath.of_yojson: not string"
let cwd () =
Fpath.v (Unix.getcwd ())
let cwd_append p =
Fpath.append (cwd ()) p
let rem_find_prefix p1 p2 =
let prefix = Option.get (Fpath.find_prefix p1 p2) in
Option.get (Fpath.rem_prefix prefix p2)