src/Pure/Tools/update_theorems.scala
author haftmann
Sun, 13 Mar 2016 10:22:46 +0100
changeset 62608 19f87fa0cfcb
parent 62454 38c89353b349
child 62836 98dbed6cfa44
permissions -rw-r--r--
more theorems on orderings
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
61337
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Tools/update_theorems.scala
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     3
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     4
Update toplevel theorem keywords.
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     5
*/
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     6
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     7
package isabelle
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     8
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
     9
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    10
object Update_Theorems
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    11
{
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    12
  def update_theorems(path: Path)
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    13
  {
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    14
    val text0 = File.read(path)
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    15
    val text1 =
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    16
      (for (tok <- Token.explode(Keyword.Keywords.empty, text0).iterator)
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    17
        yield {
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    18
          tok.source match {
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    19
            case "theorems" => "lemmas"
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    20
            case "schematic_theorem" | "schematic_lemma" | "schematic_corollary" =>
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    21
              "schematic_goal"
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    22
            case s => s
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    23
        } }).mkString
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    24
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    25
    if (text0 != text1) {
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    26
      Output.writeln("changing " + path)
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    27
      File.write_backup2(path, text1)
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    28
    }
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    29
  }
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    30
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    31
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    32
  /* command line entry point */
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    33
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    34
  def main(args: Array[String])
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    35
  {
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    36
    Command_Line.tool0 {
62454
38c89353b349 tuned signature;
wenzelm
parents: 62450
diff changeset
    37
      val getopts = Getopts("""
62450
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    38
Usage: isabelle update_theorems [FILES|DIRS...]
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    39
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    40
  Recursively find .thy files and update toplevel theorem keywords:
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    41
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    42
    theorems             ~>  lemmas
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    43
    schematic_theorem    ~>  schematic_goal
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    44
    schematic_lemma      ~>  schematic_goal
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    45
    schematic_corollary  ~>  schematic_goal
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    46
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    47
  Old versions of files are preserved by appending "~~".
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    48
""")
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    49
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    50
      val specs = getopts(args)
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    51
      if (specs.isEmpty) getopts.usage()
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    52
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    53
      for {
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    54
        spec <- specs
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    55
        file <- File.find_files(Path.explode(spec).file, file => file.getName.endsWith(".thy"))
2154f709fc25 moved getopts to Scala;
wenzelm
parents: 61337
diff changeset
    56
      } update_theorems(Path.explode(File.standard_path(file)))
61337
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    57
    }
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    58
  }
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents:
diff changeset
    59
}