src/Pure/Thy/thy_info.scala
author wenzelm
Tue, 16 Aug 2011 21:13:52 +0200
changeset 44222 9d5ef6cd4ee1
parent 44159 9a35e88d9dc9
child 44225 a8f921e6484f
permissions -rw-r--r--
use full .thy file name as node name, which makes MiscUtilities.resolveSymlinks/File.getCanonicalPath more predictable; more robust treatment of node dependencies; misc tuning;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
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
43673
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    10
object Thy_Info
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    11
{
44222
9d5ef6cd4ee1 use full .thy file name as node name, which makes MiscUtilities.resolveSymlinks/File.getCanonicalPath more predictable;
wenzelm
parents: 44159
diff changeset
    12
  /* base name */
9d5ef6cd4ee1 use full .thy file name as node name, which makes MiscUtilities.resolveSymlinks/File.getCanonicalPath more predictable;
wenzelm
parents: 44159
diff changeset
    13
9d5ef6cd4ee1 use full .thy file name as node name, which makes MiscUtilities.resolveSymlinks/File.getCanonicalPath more predictable;
wenzelm
parents: 44159
diff changeset
    14
  def base_name(s: String): String = Path.explode(s).base.implode
9d5ef6cd4ee1 use full .thy file name as node name, which makes MiscUtilities.resolveSymlinks/File.getCanonicalPath more predictable;
wenzelm
parents: 44159
diff changeset
    15
9d5ef6cd4ee1 use full .thy file name as node name, which makes MiscUtilities.resolveSymlinks/File.getCanonicalPath more predictable;
wenzelm
parents: 44159
diff changeset
    16
43673
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    17
  /* protocol messages */
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    18
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    19
  object Loaded_Theory {
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    20
    def unapply(msg: XML.Tree): Option[String] =
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    21
      msg match {
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    22
        case XML.Elem(Markup(Markup.LOADED_THEORY, List((Markup.NAME, name))), _) => Some(name)
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    23
        case _ => None
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    24
      }
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    25
  }
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    26
}
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    27
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    28
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    29
class Thy_Info(thy_load: Thy_Load)
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    30
{
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    31
  /* messages */
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    32
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    33
  private def show_path(names: List[String]): String =
43652
dcd0b667f73d pervasive Basic_Library in Scala;
wenzelm
parents: 43651
diff changeset
    34
    names.map(quote).mkString(" via ")
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    35
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    36
  private def cycle_msg(names: List[String]): String =
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    37
    "Cyclic dependency of " + show_path(names)
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    38
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    39
  private def required_by(s: String, initiators: List[String]): String =
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    40
    if (initiators.isEmpty) ""
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    41
    else s + "(required by " + show_path(initiators.reverse) + ")"
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    42
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    43
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    44
  /* dependencies */
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    45
44159
9a35e88d9dc9 simplified class Thy_Header;
wenzelm
parents: 43674
diff changeset
    46
  type Deps = Map[String, Exn.Result[(String, Thy_Header)]]  // name -> (text, header)
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    47
43673
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    48
  private def require_thys(ignored: String => Boolean,
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    49
      initiators: List[String], dir: Path, deps: Deps, strs: List[String]): Deps =
43673
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    50
    (deps /: strs)(require_thy(ignored, initiators, dir, _, _))
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    51
43673
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    52
  private def require_thy(ignored: String => Boolean,
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    53
      initiators: List[String], dir: Path, deps: Deps, str: String): Deps =
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    54
  {
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    55
    val path = Path.explode(str)
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    56
    val name = path.base.implode
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    57
43673
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    58
    if (deps.isDefinedAt(name) || ignored(name)) deps
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    59
    else {
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    60
      val dir1 = dir + path.dir
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    61
      try {
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    62
        if (initiators.contains(name)) error(cycle_msg(initiators))
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    63
        val (text, header) =
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    64
          try { thy_load.check_thy(dir1, name) }
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    65
          catch {
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    66
            case ERROR(msg) =>
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    67
              cat_error(msg, "The error(s) above occurred while examining theory " +
43652
dcd0b667f73d pervasive Basic_Library in Scala;
wenzelm
parents: 43651
diff changeset
    68
                quote(name) + required_by("\n", initiators))
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    69
          }
43673
29eb1cd29961 Thy_Info.dependencies: ignore already loaded theories, according to initial prover session status;
wenzelm
parents: 43652
diff changeset
    70
        require_thys(ignored, name :: initiators, dir1,
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    71
          deps + (name -> Exn.Res(text, header)), header.imports)
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    72
      }
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    73
      catch { case e: Throwable => deps + (name -> Exn.Exn(e)) }
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    74
    }
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    75
  }
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    76
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    77
  def dependencies(dir: Path, str: String): Deps =
43674
3ddaa75c669c tuned comment (cf. e9f26e66692d);
wenzelm
parents: 43673
diff changeset
    78
    require_thy(thy_load.is_loaded, Nil, dir, Map.empty, str)
43651
511df47bcadc some support for theory files within Isabelle/Scala session;
wenzelm
parents:
diff changeset
    79
}