author | wenzelm |
Tue, 25 Jul 2023 12:27:31 +0200 | |
changeset 78452 | 14ceb9a51e97 |
parent 78450 | 14219730e04f |
child 79095 | 3bdd3cf5f5e0 |
permissions | -rw-r--r-- |
78315 | 1 |
(* Title: Tools/profiling.ML |
2 |
Author: Makarius |
|
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
3 |
|
78315 | 4 |
Session profiling based on loaded ML image. |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
5 |
*) |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
6 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
7 |
signature PROFILING = |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
8 |
sig |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
9 |
val locales: theory -> string list |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
10 |
val locale_thms: theory -> string -> thm list |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
11 |
val locales_thms: theory -> thm list |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
12 |
val global_thms: theory -> thm list |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
13 |
val all_thms: theory -> thm list |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
14 |
type session_statistics = |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
15 |
{theories: int, |
78450 | 16 |
garbage_theories: int, |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
17 |
locales: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
18 |
locale_thms: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
19 |
global_thms: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
20 |
sizeof_thys_id: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
21 |
sizeof_thms_id: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
22 |
sizeof_terms: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
23 |
sizeof_types: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
24 |
sizeof_spaces: int} |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
25 |
val session_statistics: string list -> session_statistics |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
26 |
val main: unit -> unit |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
27 |
end; |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
28 |
|
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
29 |
structure Profiling: PROFILING = |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
30 |
struct |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
31 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
32 |
(* theory content *) |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
33 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
34 |
fun locales thy = |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
35 |
let |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
36 |
val parent_spaces = map Locale.locale_space (Theory.parents_of thy); |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
37 |
fun add name = |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
38 |
if exists (fn space => Name_Space.declared space name) parent_spaces then I |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
39 |
else cons name; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
40 |
in fold add (Locale.get_locales thy) [] end; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
41 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
42 |
fun proper_thm thm = not (Thm.eq_thm_prop (Drule.dummy_thm, thm)); |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
43 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
44 |
fun locale_thms thy loc = |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
45 |
(Locale.locale_notes thy loc, []) |-> |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
46 |
(fold (#2 #> fold (#2 #> (fold (#1 #> fold (fn thm => proper_thm thm ? cons thm )))))); |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
47 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
48 |
fun locales_thms thy = |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
49 |
maps (locale_thms thy) (locales thy); |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
50 |
|
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
51 |
fun global_thms thy = |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
52 |
Facts.dest_static true |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
53 |
(map Global_Theory.facts_of (Theory.parents_of thy)) (Global_Theory.facts_of thy) |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
54 |
|> maps #2; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
55 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
56 |
fun all_thms thy = locales_thms thy @ global_thms thy; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
57 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
58 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
59 |
(* session content *) |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
60 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
61 |
fun session_content thys = |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
62 |
let |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
63 |
val thms = maps all_thms thys; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
64 |
val thys_id = map Context.theory_id thys; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
65 |
val thms_id = map Thm.theory_id thms; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
66 |
val terms = (fold o Thm.fold_terms {hyps = true}) cons thms []; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
67 |
val types = (fold o fold_types) cons terms []; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
68 |
val spaces = |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
69 |
maps (fn f => map f thys) |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
70 |
[Sign.class_space, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
71 |
Sign.type_space, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
72 |
Sign.const_space, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
73 |
Theory.axiom_space, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
74 |
Thm.oracle_space, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
75 |
Global_Theory.fact_space, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
76 |
Locale.locale_space, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
77 |
Attrib.attribute_space o Context.Theory, |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
78 |
Method.method_space o Context.Theory]; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
79 |
in {thys_id = thys_id, thms_id = thms_id, terms = terms, types = types, spaces = spaces} end; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
80 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
81 |
fun sizeof_diff (a, b) = ML_Heap.sizeof a - ML_Heap.sizeof b; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
82 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
83 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
84 |
(* session statistics *) |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
85 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
86 |
type session_statistics = |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
87 |
{theories: int, |
78450 | 88 |
garbage_theories: int, |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
89 |
locales: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
90 |
locale_thms: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
91 |
global_thms: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
92 |
sizeof_thys_id: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
93 |
sizeof_thms_id: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
94 |
sizeof_terms: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
95 |
sizeof_types: int, |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
96 |
sizeof_spaces: int}; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
97 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
98 |
fun session_statistics theories : session_statistics = |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
99 |
let |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
100 |
val theories_member = Symtab.defined (Symtab.make_set theories) o Context.theory_long_name; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
101 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
102 |
val context_thys = |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
103 |
#contexts (Context.finish_tracing ()) |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
104 |
|> map_filter (fn (Context.Theory thy, _) => SOME thy | _ => NONE); |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
105 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
106 |
val loader_thys = map Thy_Info.get_theory (Thy_Info.get_names ()); |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
107 |
val loaded_thys = filter theories_member loader_thys; |
78450 | 108 |
val loaded_context_thys = filter theories_member context_thys; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
109 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
110 |
val all_thys = loader_thys @ context_thys; |
78449 | 111 |
val base_thys = filter_out theories_member all_thys; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
112 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
113 |
val {thys_id = all_thys_id, thms_id = all_thms_id, terms = all_terms, |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
114 |
types = all_types, spaces = all_spaces} = session_content all_thys; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
115 |
val {thys_id = base_thys_id, thms_id = base_thms_id, terms = base_terms, |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
116 |
types = base_types, spaces = base_spaces} = session_content base_thys; |
78450 | 117 |
|
118 |
val n = length loaded_thys; |
|
78452 | 119 |
val m = (case length loaded_context_thys of 0 => 0 | l => l - n); |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
120 |
in |
78450 | 121 |
{theories = n, |
122 |
garbage_theories = m, |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
123 |
locales = Integer.sum (map (length o locales) loaded_thys), |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
124 |
locale_thms = Integer.sum (map (length o locales_thms) loaded_thys), |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
125 |
global_thms = Integer.sum (map (length o global_thms) loaded_thys), |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
126 |
sizeof_thys_id = sizeof_diff (all_thys_id, base_thys_id), |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
127 |
sizeof_thms_id = sizeof_diff (all_thms_id, base_thms_id), |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
128 |
sizeof_terms = sizeof_diff (all_terms, base_terms), |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
129 |
sizeof_types = sizeof_diff (all_types, base_types), |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
130 |
sizeof_spaces = sizeof_diff (all_spaces, base_spaces)} |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
131 |
end; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
132 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
133 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
134 |
(* main entry point for external process *) |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
135 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
136 |
local |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
137 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
138 |
val decode_args : string list XML.Decode.T = |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
139 |
let open XML.Decode in list string end; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
140 |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
141 |
val encode_result : session_statistics XML.Encode.T = |
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
142 |
(fn {theories = a, |
78450 | 143 |
garbage_theories = b, |
144 |
locales = c, |
|
145 |
locale_thms = d, |
|
146 |
global_thms = e, |
|
147 |
sizeof_thys_id = f, |
|
148 |
sizeof_thms_id = g, |
|
149 |
sizeof_terms = h, |
|
150 |
sizeof_types = i, |
|
151 |
sizeof_spaces = j} => ((a, (b, (c, (d, (e, (f, (g, (h, (i, j))))))))))) #> |
|
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
152 |
let open XML.Encode |
78450 | 153 |
in pair int (pair int (pair int (pair int (pair int (pair int (pair int (pair int (pair int int)))))))) end; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
154 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
155 |
in |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
156 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
157 |
fun main () = |
78315 | 158 |
(case getenv "ISABELLE_PROFILING" of |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
159 |
"" => () |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
160 |
| dir_name => |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
161 |
let |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
162 |
val dir = Path.explode dir_name; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
163 |
val args = decode_args (YXML.parse_body (File.read (dir + \<^path>\<open>args.yxml\<close>))); |
78328
007b04dc6f96
clarified session_statistics: removed somewhat pointless per-theory statistics;
wenzelm
parents:
78315
diff
changeset
|
164 |
val result = session_statistics args; |
78314
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
165 |
in File.write (dir + \<^path>\<open>result.yxml\<close>) (YXML.string_of_body (encode_result result)) end); |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
166 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
167 |
end; |
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
168 |
|
1588bec693c2
copy/rename files from private autocorres version e45b9b680d3e;
wenzelm
parents:
diff
changeset
|
169 |
end; |