| 
23250
 | 
     1  | 
structure HOL = 
  | 
| 
21147
 | 
     2  | 
struct
  | 
| 
 | 
     3  | 
  | 
| 
26513
 | 
     4  | 
type 'a eq = {eq : 'a -> 'a -> bool};
 | 
| 
 | 
     5  | 
fun eq (A_:'a eq) = #eq A_;
  | 
| 
 | 
     6  | 
  | 
| 
 | 
     7  | 
fun eqop A_ a = eq A_ a;
  | 
| 
21147
 | 
     8  | 
  | 
| 
23250
 | 
     9  | 
end; (*struct HOL*)
  | 
| 
21147
 | 
    10  | 
  | 
| 
 | 
    11  | 
structure List = 
  | 
| 
 | 
    12  | 
struct
  | 
| 
 | 
    13  | 
  | 
| 
25370
 | 
    14  | 
fun member A_ x (y :: ys) =
  | 
| 
 | 
    15  | 
  (if HOL.eqop A_ y x then true else member A_ x ys)
  | 
| 
23850
 | 
    16  | 
  | member A_ x [] = false;
  | 
| 
21147
 | 
    17  | 
  | 
| 
 | 
    18  | 
end; (*struct List*)
  | 
| 
 | 
    19  | 
  | 
| 
 | 
    20  | 
structure Codegen = 
  | 
| 
 | 
    21  | 
struct
  | 
| 
 | 
    22  | 
  | 
| 
25182
 | 
    23  | 
fun collect_duplicates A_ xs ys (z :: zs) =
  | 
| 
 | 
    24  | 
  (if List.member A_ z xs
  | 
| 
 | 
    25  | 
    then (if List.member A_ z ys then collect_duplicates A_ xs ys zs
  | 
| 
 | 
    26  | 
           else collect_duplicates A_ xs (z :: ys) zs)
  | 
| 
 | 
    27  | 
    else collect_duplicates A_ (z :: xs) (z :: ys) zs)
  | 
| 
 | 
    28  | 
  | collect_duplicates A_ xs ys [] = xs;
  | 
| 
21147
 | 
    29  | 
  | 
| 
 | 
    30  | 
end; (*struct Codegen*)
  |