| author | kuncar |
| Fri, 23 Mar 2012 14:25:31 +0100 | |
| changeset 47096 | 3ea48c19673e |
| parent 46737 | 09ab89658a5d |
| child 48707 | ba531af91148 |
| permissions | -rw-r--r-- |
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
1 |
/* Title: Pure/Thy/thy_info.scala |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
2 |
Author: Makarius |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
3 |
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
4 |
Theory and file dependencies. |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
5 |
*/ |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
6 |
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
7 |
package isabelle |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
8 |
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
9 |
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
10 |
class Thy_Info(thy_load: Thy_Load) |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
11 |
{
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
12 |
/* messages */ |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
13 |
|
| 44615 | 14 |
private def show_path(names: List[Document.Node.Name]): String = |
15 |
names.map(name => quote(name.theory)).mkString(" via ")
|
|
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
16 |
|
| 44615 | 17 |
private def cycle_msg(names: List[Document.Node.Name]): String = |
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
18 |
"Cyclic dependency of " + show_path(names) |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
19 |
|
| 44615 | 20 |
private def required_by(initiators: List[Document.Node.Name]): String = |
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
21 |
if (initiators.isEmpty) "" |
| 44615 | 22 |
else "\n(required by " + show_path(initiators.reverse) + ")" |
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
23 |
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
24 |
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
25 |
/* dependencies */ |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
26 |
|
|
44954
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
27 |
type Dep = (Document.Node.Name, Document.Node_Header) |
|
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
28 |
private type Required = (List[Dep], Set[Document.Node.Name]) |
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
29 |
|
| 44615 | 30 |
private def require_thys(initiators: List[Document.Node.Name], |
|
44954
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
31 |
required: Required, names: List[Document.Node.Name]): Required = |
|
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
32 |
(required /: names)(require_thy(initiators, _, _)) |
| 44615 | 33 |
|
34 |
private def require_thy(initiators: List[Document.Node.Name], |
|
|
44954
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
35 |
required: Required, name: Document.Node.Name): Required = |
| 44615 | 36 |
{
|
|
44954
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
37 |
val (deps, seen) = required |
|
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
38 |
if (seen(name)) required |
|
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
39 |
else if (thy_load.is_loaded(name.theory)) (deps, seen + name) |
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
40 |
else {
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
41 |
try {
|
| 44615 | 42 |
if (initiators.contains(name)) error(cycle_msg(initiators)) |
| 46737 | 43 |
val node_deps = |
| 44615 | 44 |
try { thy_load.check_thy(name) }
|
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
45 |
catch {
|
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
46 |
case ERROR(msg) => |
| 44615 | 47 |
cat_error(msg, "The error(s) above occurred while examining theory " + |
48 |
quote(name.theory) + required_by(initiators)) |
|
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
49 |
} |
| 46737 | 50 |
val (deps1, seen1) = |
51 |
require_thys(name :: initiators, (deps, seen + name), node_deps.imports) |
|
52 |
((name, Exn.Res(node_deps)) :: deps1, seen1) |
|
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
53 |
} |
|
44954
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
54 |
catch { case e: Throwable => (((name, Exn.Exn(e)): Dep) :: deps, seen + name) }
|
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
55 |
} |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
56 |
} |
|
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
57 |
|
|
44954
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
58 |
def dependencies(names: List[Document.Node.Name]): List[Dep] = |
|
b536b1144eb3
more careful traversal of theory dependencies to retain standard import order;
wenzelm
parents:
44616
diff
changeset
|
59 |
require_thys(Nil, (Nil, Set.empty), names)._1.reverse |
|
43651
511df47bcadc
some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff
changeset
|
60 |
} |