This file is indexed.

/usr/share/hol88-2.02.19940316/contrib/hol-exec/cons.ml is in hol88-contrib-source 2.02.19940316-19.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
%------ FILE cons.ml ------%
% Bug fixed in an earlier version %
% sree@cs.ubc.ca %

letrec get_final_ret_type1 cons_type =
        if ((can dest_type) cons_type) then
           let t1 = dest_type cons_type in
           if (null (snd t1)) then cons_type
           else
             if ((fst t1) = `fun`) then
              get_final_ret_type1 (hd (rev (snd t1)))
             else cons_type
        else
           failwith `not a type`;;

let get_final_ret_type cons_term =
       get_final_ret_type1 (type_of cons_term);;

let get_type_axiom_from thy const_term =
       if (is_const const_term) then
          let typ = fst (dest_type (get_final_ret_type const_term)) in
          (let thm_name = concat typ `_Axiom` in
            (get_second thm_name (theorems thy)))
       else
           failwith `get_type_axiom_from: not a constant`;;

let mk_cons_tuple_str_list1 functor arg_list =
     if (null arg_list) then
        concat `CONS__`
         (concat (const_var_to_string functor) `;; \L`)
     else
      concat `CONS__`
       (concat (const_var_to_string functor)
         (concat ` (`
           (concat (inv_words `,` (map const_var_to_string arg_list))
                   `);; \L`)));;
                    
let mk_cons_tuple_str_list thy const_term =
      let t1 = concl (get_type_axiom_from thy const_term) in
       (let list_list = get_args (skolemize t1) in
         (let functor_list = functors_of_args list_list and
              args_list = args_of_args list_list in
            (map2 (uncurry mk_cons_tuple_str_list1) (functor_list,args_list))));;

let is_constructor_from thy const_term = 
      if ((can (get_type_axiom_from thy) ) const_term) then
       let t1 = concl (get_type_axiom_from thy const_term) in
        (let list_list = get_args (skolemize t1) in
         (let functor_list = functors_of_args list_list in
           (let const_name = fst (dest_const const_term) and
                functor_name_list = map fst (map dest_const functor_list) in
           mem const_name functor_name_list)))
      else
        false;;

letrec mk_quick_cons_def_from thy const_term =
      let t1 = concl (get_type_axiom_from thy const_term) in
          (let list_list = get_args (skolemize t1) in
           (let functor_list = functors_of_args list_list in
            (let const_name = fst (dest_const const_term) and
                 functor_name_list = map fst (map dest_const functor_list) in
            (let el_index = index const_name functor_name_list in
              (let args = el el_index (args_of_args list_list) in 
               (let cons_args_term_list = const_term.args in
                (let str_list = map const_var_to_ml_string cons_args_term_list in
                (let let_str =
                  concat `let `
                  (concat (inv_words ` ` str_list)
                   (concat ` = `
                           (mk_cons_tuple_str_list1 const_term args)
                           )) in
                 let_str))))))));;

let type_map = [(`num`,`int`)];;

% Does not capture type constructors like `fun` : retain for safety
letrec mk_type_list hol_type =
      let type_pair = ((dest_type hol_type) ? ((dest_vartype hol_type),[])) in
       (let type1_str = lookup_map type_map (fst type_pair) and
            type2 = snd type_pair in
       if (null type2) then [type1_str]
       else
         append (mk_type_list (hd type2)) [type1_str]);;
%

% Fix the above %
letrec mk_type_list hol_type_list =
      if (null hol_type_list) then []
      else
      let head = hd hol_type_list in
      let type_pair = ((dest_type head) ? ((dest_vartype head),[])) in
      let first = fst type_pair and
          secnd = snd type_pair in
      if (first = `prod`) then
         [inv_words `#` (mk_type_list secnd)]
      else
      if (first = `fun`) then 
         [inv_words `->` (mk_type_list secnd)]
      else
      let type1_str = lookup_map type_map first in
        if (null secnd) then
         type1_str.(mk_type_list (tl hol_type_list))
        else
         (`(`^(inv_words `,` (mk_type_list secnd))^`)`^type1_str).
         (mk_type_list (tl hol_type_list));;
                      
let hol_to_ml_type hol_type = 
      inv_words ` ` (mk_type_list [hol_type]);;

let mk_constructor_defs_strs functor arg_type_list =
      if (null arg_type_list) then 
       concat `CONS__`
               (const_var_to_string functor)
      else
       concat `CONS__`
        (concat (const_var_to_string functor)
	  (concat ` of `
	          (inv_words ` # ` (map hol_to_ml_type arg_type_list))));;

let mk_cons_type_defs1 thy const_term =
      let t1 = concl (get_type_axiom_from thy const_term) in
          (let list_list = get_args (skolemize t1) in
           (let functor_list = functors_of_args list_list in
            (let const_name = fst (dest_const const_term) and
                 functor_name_list = map fst (map dest_const functor_list) in
            (let el_index = index const_name functor_name_list in
              (let args = el el_index (args_of_args list_list) in 
               (let arg_type_list = map type_of args in
           mk_constructor_defs_strs const_term arg_type_list))))));;

let mk_cons_type_defs_str thy cons_list_pair =
% create a unique name for the rectype%
       let rectype_name = hol_to_ml_type (fst cons_list_pair) and
           cons_list = snd cons_list_pair in
       (concat `rectype `
	 (concat rectype_name
	   (concat ` = `
% We could also sort the cons_list according to type minimality,
  though its not required by ML - but we will just use reverse %
	     (concat (inv_words `| ` (map (mk_cons_type_defs1 thy) (rev cons_list)))
                     `;;\L\L`))));;

let map_map f l = map (map f) l;;
letrec mapl l1 l2 =
    if (null l1) then []
    else
       ((hd l1) (hd l2)). (mapl (tl l1) (tl l2));;

let mk_pair_list l1 l2 =
     mapl (map pair l1) l2;;

letrec mk_groups_of_same_type cons_list_pair =
      if (null cons_list_pair) then []
      else
         let type_eq term1 term2 =
                 (snd term1) = 
                 (snd term2) in
         (let type1_list_pair = (sublist (type_eq (hd cons_list_pair)) 
                                                   cons_list_pair) in
           (let cons_list_pair1 = subtract cons_list_pair type1_list_pair in
            (let type1_list = map fst type1_list_pair and
                 type1 = (snd (hd type1_list_pair)) in
             ((type1,type1_list).(mk_groups_of_same_type cons_list_pair1)))));;

let mk_cons_type_defs thy cons_list =
       (let type_list = map get_final_ret_type cons_list in
% We should actually sort the type groups according to containment,
  but we will for the moment assume a reverse order creation: %
        (let cons_list_list = rev 
                               (mk_groups_of_same_type 
                                  (mk_pair_list cons_list type_list)) in
             map (mk_cons_type_defs_str thy) cons_list_list));;


% The following is too complicated and unnecessary
letrec mk_groups_of_same_type cons_list =
      if (null cons_list) then []
      else
         let type_eq term1 term2 =
                 type_of term1 = type_of term2 in
         (let type1_list = sublist (type_eq (hd cons_list)) cons_list in
           (let cons_list1 = subtract cons_list type1_list in
             (type1_list.(mk_groups_of_same_type cons_list1))));;

let map_map f l = map (map f) l;;
letrec mapl l1 l2 =
    if (null l1) then []
    else
       ((hd l1) (hd l2)). (mapl (tl l1) (tl l2));;

let mk_cons_type_defs1 cons_list =
          (let list_list = map get_args (map skolemize cons_list) in
           (let functor_list_list = map functors_of_args list_list in
            (let const_name_list = map fst (map dest_const cons_list) and
                 functor_name_list_list = map_map fst 
                                     (map_map dest_const functor_list_list) in
            (let el_index_list = mapl (map index const_name_list) 
                                        functor_name_list_list in
              (let args_list_list = map_map type_of
                                        (mapl (map el el_index_list)
                                          (map args_of_args list_list)) in 
               mk_cons_defs cons_list args_list_list)))));;
    
let mk_cons_type_defs thy cons_list =
       let t1_list = map concl (map (get_type_axiom_from thy) cons_list) in
        (let cons_list_list = mk_groups_of_same_type cons_list in
         (let def_str_list = map mk_cons_type_defs1 cons_list_list in
           def_str_list));;



%