author | wenzelm |
Tue, 11 Aug 2015 20:32:56 +0200 | |
changeset 60900 | 11a0f333de6f |
parent 60099 | 73c260342704 |
child 60948 | b710a5087116 |
permissions | -rw-r--r-- |
60093 | 1 |
(* Title: Pure/Tools/thy_deps.ML |
2 |
Author: Makarius |
|
3 |
||
4 |
Visualization of theory dependencies. |
|
5 |
*) |
|
6 |
||
7 |
signature THY_DEPS = |
|
8 |
sig |
|
60099 | 9 |
val thy_deps: Proof.context -> theory list option * theory list option -> Graph_Display.entry list |
10 |
val thy_deps_cmd: Proof.context -> |
|
11 |
(string * Position.T) list option * (string * Position.T) list option -> unit |
|
60093 | 12 |
end; |
13 |
||
14 |
structure Thy_Deps: THY_DEPS = |
|
15 |
struct |
|
16 |
||
60099 | 17 |
fun gen_thy_deps _ ctxt (NONE, NONE) = |
60093 | 18 |
let |
19 |
val parent_session = Session.get_name (); |
|
20 |
val parent_loaded = is_some o Thy_Info.lookup_theory; |
|
60099 | 21 |
in Present.session_graph parent_session parent_loaded (Proof_Context.theory_of ctxt) end |
22 |
| gen_thy_deps prep_thy ctxt bounds = |
|
60093 | 23 |
let |
60099 | 24 |
val (upper, lower) = apply2 ((Option.map o map) (prep_thy ctxt)) bounds; |
60093 | 25 |
val rel = Theory.subthy o swap; |
26 |
val pred = |
|
27 |
(case upper of |
|
28 |
SOME Bs => (fn thy => exists (fn B => rel (thy, B)) Bs) |
|
29 |
| NONE => K true) andf |
|
30 |
(case lower of |
|
31 |
SOME Bs => (fn thy => exists (fn B => rel (B, thy)) Bs) |
|
32 |
| NONE => K true); |
|
33 |
fun node thy = |
|
34 |
((Context.theory_name thy, Graph_Display.content_node (Context.theory_name thy) []), |
|
35 |
map Context.theory_name (filter pred (Theory.parents_of thy))); |
|
60099 | 36 |
in map node (filter pred (Theory.nodes_of (Proof_Context.theory_of ctxt))) end; |
60093 | 37 |
|
60099 | 38 |
val thy_deps = |
39 |
gen_thy_deps (fn ctxt => fn thy => |
|
40 |
let val thy0 = Proof_Context.theory_of ctxt |
|
41 |
in if Theory.subthy (thy, thy0) then thy else raise THEORY ("Bad theory", [thy, thy0]) end); |
|
42 |
||
43 |
val thy_deps_cmd = Graph_Display.display_graph oo gen_thy_deps Theory.check; |
|
60093 | 44 |
|
45 |
val theory_bounds = |
|
60099 | 46 |
Parse.position Parse.theory_xname >> single || |
47 |
(@{keyword "("} |-- Parse.enum "|" (Parse.position Parse.theory_xname) --| @{keyword ")"}); |
|
60093 | 48 |
|
49 |
val _ = |
|
50 |
Outer_Syntax.command @{command_keyword thy_deps} "visualize theory dependencies" |
|
60097
d20ca79d50e4
discontinued pointless warnings: commands are only defined inside a theory context;
wenzelm
parents:
60093
diff
changeset
|
51 |
(Scan.option theory_bounds -- Scan.option theory_bounds >> |
60099 | 52 |
(fn args => Toplevel.keep (fn st => thy_deps_cmd (Toplevel.context_of st) args))); |
60093 | 53 |
|
54 |
end; |