src/Pure/Tools/mkroot.scala
author wenzelm
Sat, 11 Nov 2017 14:35:41 +0100
changeset 67041 f8b0367046bd
child 67042 677cab7c2b85
permissions -rw-r--r--
converted to Isabelle/Scala;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
67041
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Tools/mkroot.scala
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     3
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     4
Prepare session root directory.
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     5
*/
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     6
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     7
package isabelle
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     8
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
     9
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    10
object Mkroot
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    11
{
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    12
  /** mkroot **/
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    13
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    14
  def root_name(name: String): String =
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    15
    Token.quote_name(Sessions.root_syntax.keywords, name)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    16
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    17
  def latex_name(name: String): String =
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    18
    (for (c <- name.iterator if c != '\\')
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    19
     yield if (c == '_') '-' else c).mkString
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    20
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    21
  def mkroot(
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    22
    session_name: String = "",
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    23
    session_dir: Path = Path.current,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    24
    session_parent: String = "",
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    25
    document: Boolean = false,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    26
    title: String = "",
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    27
    author: String = "",
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    28
    progress: Progress = No_Progress)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    29
  {
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    30
    Isabelle_System.mkdirs(session_dir)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    31
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    32
    val name = proper_string(session_name) getOrElse session_dir.absolute_file.getName
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    33
    val parent = proper_string(session_parent) getOrElse Isabelle_System.getenv("ISABELLE_LOGIC")
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    34
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    35
    val root_path = session_dir + Path.explode("ROOT")
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    36
    if (root_path.file.exists) error("Cannot overwrite existing " + root_path)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    37
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    38
    val document_path = session_dir + Path.explode("document")
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    39
    if (document && document_path.file.exists) error("Cannot overwrite existing " + document_path)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    40
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    41
    progress.echo("\nPreparing session " + quote(name) + " in " + session_dir)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    42
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    43
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    44
    /* ROOT */
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    45
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    46
    progress.echo("  creating " + root_path)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    47
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    48
    File.write(root_path,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    49
      "session " + root_name(name) + " = " + root_name(parent) + " +" +
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    50
      (if (document) """
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    51
  options [document = pdf, document_output = "output"]
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    52
  theories [document = false]
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    53
    (* Foo *)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    54
    (* Bar *)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    55
  theories
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    56
    (* Baz *)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    57
  document_files
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    58
    "root.tex"
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    59
"""
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    60
      else """
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    61
  options [document = false]
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    62
  theories
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    63
    (* Foo *)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    64
    (* Bar *)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    65
    (* Baz *)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    66
"""))
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    67
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    68
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    69
    /* document directory */
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    70
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    71
    if (document) {
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    72
      val root_tex = session_dir + Path.explode("document/root.tex")
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    73
      progress.echo("  creating " + root_tex)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    74
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    75
      Isabelle_System.mkdirs(root_tex.dir)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    76
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    77
      File.write(root_tex,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    78
"""\documentclass[11pt,a4paper]{article}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    79
\""" + """usepackage{isabelle,isabellesym}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    80
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    81
% further packages required for unusual symbols (see also
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    82
% isabellesym.sty), use only when needed
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    83
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    84
%\""" + """usepackage{amssymb}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    85
  %for \<leadsto>, \<box>, \<diamond>, \<sqsupset>, \<mho>, \<Join>,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    86
  %\<lhd>, \<lesssim>, \<greatersim>, \<lessapprox>, \<greaterapprox>,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    87
  %\<triangleq>, \<yen>, \<lozenge>
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    88
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    89
%\""" + """usepackage{eurosym}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    90
  %for \<euro>
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    91
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    92
%\""" + """usepackage[only,bigsqcap]{stmaryrd}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    93
  %for \<Sqinter>
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    94
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    95
%\""" + """usepackage{eufrak}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    96
  %for \<AA> ... \<ZZ>, \<aa> ... \<zz> (also included in amssymb)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    97
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    98
%\""" + """usepackage{textcomp}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
    99
  %for \<onequarter>, \<onehalf>, \<threequarters>, \<degree>, \<cent>,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   100
  %\<currency>
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   101
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   102
% this should be the last package used
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   103
\""" + """usepackage{pdfsetup}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   104
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   105
% urls in roman style, theory text in math-similar italics
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   106
\""" + """urlstyle{rm}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   107
\isabellestyle{it}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   108
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   109
% for uniform font size
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   110
%\renewcommand{\isastyle}{\isastyleminor}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   111
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   112
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   113
\begin{document}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   114
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   115
\title{""" + (proper_string(title) getOrElse latex_name(name)) + """}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   116
\author{""" +
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   117
  (proper_string(author) getOrElse ("By " + latex_name(Isabelle_System.getenv("USER")))) + """}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   118
\maketitle
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   119
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   120
\tableofcontents
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   121
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   122
% sane default for proof documents
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   123
\parindent 0pt\parskip 0.5ex
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   124
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   125
% generated text of all theories
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   126
\input{session}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   127
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   128
% optional bibliography
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   129
%\bibliographystyle{abbrv}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   130
%\bibliography{root}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   131
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   132
\end{document}
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   133
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   134
%%% Local Variables:
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   135
%%% mode: latex
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   136
%%% TeX-master: t
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   137
%%% End:
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   138
""")
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   139
    }
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   140
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   141
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   142
    /* notes */
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   143
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   144
    {
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   145
      val print_dir = session_dir.implode
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   146
      progress.echo("""
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   147
Now use the following command line to build the session:
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   148
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   149
  isabelle build -D """ +
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   150
        (if (Bash.string(print_dir) == print_dir) print_dir else quote(print_dir)) + "\n")
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   151
    }
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   152
  }
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   153
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   154
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   155
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   156
  /** Isabelle tool wrapper **/
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   157
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   158
  val isabelle_tool = Isabelle_Tool("mkroot", "prepare session root directory", args =>
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   159
  {
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   160
    var document = false
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   161
    var session_name = ""
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   162
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   163
    val getopts = Getopts("""
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   164
Usage: isabelle mkroot [OPTIONS] [DIR]
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   165
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   166
  Options are:
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   167
    -d           enable document preparation
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   168
    -n NAME      alternative session name (default: DIR base name)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   169
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   170
  Prepare session root DIR (default: current directory).
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   171
""",
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   172
      "d" -> (_ => document = true),
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   173
      "n:" -> (arg => session_name = arg))
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   174
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   175
    val more_args = getopts(args)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   176
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   177
    val session_dir =
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   178
      more_args match {
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   179
        case Nil => Path.current
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   180
        case List(dir) => Path.explode(dir)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   181
        case _ => getopts.usage()
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   182
      }
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   183
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   184
    mkroot(session_name = session_name, session_dir = session_dir, document = document,
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   185
      progress = new Console_Progress)
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   186
  })
f8b0367046bd converted to Isabelle/Scala;
wenzelm
parents:
diff changeset
   187
}