File: HashedFault.ml

package info (click to toggle)
herdtools7 7.58-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 19,732 kB
  • sloc: ml: 128,583; ansic: 3,827; makefile: 670; python: 407; sh: 212; awk: 14
file content (76 lines) | stat: -rw-r--r-- 3,074 bytes parent folder | download
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
(****************************************************************************)
(*                           the diy toolsuite                              *)
(*                                                                          *)
(* Jade Alglave, University College London, UK.                             *)
(* Luc Maranget, INRIA Paris-Rocquencourt, France.                          *)
(*                                                                          *)
(* Copyright 2020-present Institut National de Recherche en Informatique et *)
(* en Automatique and the authors. All rights reserved.                     *)
(*                                                                          *)
(* This software is governed by the CeCILL-B license under French law and   *)
(* abiding by the rules of distribution of free software. You can use,      *)
(* modify and/ or redistribute the software under the terms of the CeCILL-B *)
(* license as circulated by CEA, CNRS and INRIA at the following URL        *)
(* "http://www.cecill.info". We also give a copy in LICENSE.txt.            *)
(****************************************************************************)

module S = struct
  type t = int * HashedStringOpt.t * HashedStringOpt.t * HashedStringOpt.t

  let equal (p1,a1,b1,c1) (p2,a2,b2,c2) =  p1 == p2 && a1 == a2 && b1 == b2 && c1 == c2

  let hash (p,a,b,c) =
    let ah =  HashedStringOpt.as_hash a
    and bh = HashedStringOpt.as_hash b
    and ch = HashedStringOpt.as_hash c in
    abs (Misc.mix (Misc.mix (0x4F1BBCDC+ah) (0x4F1BBCDC+bh) (0x4F1BBCDC+p)) (0x4F1BBCDC+ch) 0)
end

include (Hashcons.Make(S))

let table = create 101

let as_tt h = h.Hashcons.node

let as_hashed ((p,lab),x,ft) =
  hashcons table
    (p,HashedStringOpt.as_hashed lab,
     HashedStringOpt.as_hashed x,
     HashedStringOpt.as_hashed ft)

let as_t h =
  let p,hlab,hx,hft = h.Hashcons.node in
  ((p,HashedStringOpt.as_t hlab),HashedStringOpt.as_t hx,HashedStringOpt.as_t hft)

let as_hash h = h.Hashcons.hkey

let warn_once = ref true

let compare h1 h2 =
  let p1,lab1,x1,ft1 = as_tt h1
  and p2,lab2,x2,ft2 = as_tt h2 in
  match Misc.int_compare p1 p2 with
  | 0 -> begin  match HashedStringOpt.compare lab1 lab2 with
         | 0 -> begin match HashedStringOpt.compare x1 x2 with
                | 0 -> begin match HashedStringOpt.as_t ft1, HashedStringOpt.as_t ft2 with
                       | Some ft1, Some ft2 -> String.compare ft1 ft2
                       | None, _ | _, None ->
                          if !warn_once then begin
                            Warn.warn_always "Comparing faults with and without fault type, \
                                              assuming same type";
                            warn_once := false;
                            end;
                          0
                       end
                | r -> r
                end
         | r -> r
  end
  | r -> r

let has_fault_type h =
  let _,_,_,ft = as_tt h in
  let ft = HashedStringOpt.as_t ft in
  match ft with
  | Some _ -> true
  | None -> false