| author | wenzelm | 
| Sun, 16 May 2021 23:22:03 +0200 | |
| changeset 73710 | 241cfa881788 | 
| parent 73467 | 090add96f5f9 | 
| child 74433 | ec1774613824 | 
| permissions | -rw-r--r-- | 
| 67041 | 1 | /* Title: Pure/Tools/mkroot.scala | 
| 2 | Author: Makarius | |
| 3 | ||
| 4 | Prepare session root directory. | |
| 5 | */ | |
| 6 | ||
| 7 | package isabelle | |
| 8 | ||
| 9 | ||
| 10 | object Mkroot | |
| 11 | {
 | |
| 12 | /** mkroot **/ | |
| 13 | ||
| 14 | def root_name(name: String): String = | |
| 15 | Token.quote_name(Sessions.root_syntax.keywords, name) | |
| 16 | ||
| 17 | def latex_name(name: String): String = | |
| 18 | (for (c <- name.iterator if c != '\\') | |
| 19 | yield if (c == '_') '-' else c).mkString | |
| 20 | ||
| 21 | def mkroot( | |
| 22 | session_name: String = "", | |
| 23 | session_dir: Path = Path.current, | |
| 24 | session_parent: String = "", | |
| 67069 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 25 | init_repos: Boolean = false, | 
| 67041 | 26 | title: String = "", | 
| 27 | author: String = "", | |
| 73340 | 28 | progress: Progress = new Progress): Unit = | 
| 67041 | 29 |   {
 | 
| 72375 | 30 | Isabelle_System.make_directory(session_dir) | 
| 67041 | 31 | |
| 32 | val name = proper_string(session_name) getOrElse session_dir.absolute_file.getName | |
| 33 |     val parent = proper_string(session_parent) getOrElse Isabelle_System.getenv("ISABELLE_LOGIC")
 | |
| 34 | ||
| 72832 | 35 | val root_path = session_dir + Sessions.ROOT | 
| 67041 | 36 |     if (root_path.file.exists) error("Cannot overwrite existing " + root_path)
 | 
| 37 | ||
| 38 |     val document_path = session_dir + Path.explode("document")
 | |
| 67042 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 39 |     if (document_path.file.exists) error("Cannot overwrite existing " + document_path)
 | 
| 67041 | 40 | |
| 67069 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 41 |     val root_tex = session_dir + Path.explode("document/root.tex")
 | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 42 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 43 | |
| 67041 | 44 |     progress.echo("\nPreparing session " + quote(name) + " in " + session_dir)
 | 
| 45 | ||
| 46 | ||
| 47 | /* ROOT */ | |
| 48 | ||
| 49 |     progress.echo("  creating " + root_path)
 | |
| 50 | ||
| 51 | File.write(root_path, | |
| 67042 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 52 | "session " + root_name(name) + " = " + root_name(parent) + """ + | 
| 67041 | 53 | options [document = pdf, document_output = "output"] | 
| 67042 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 54 | (*theories [document = false] | 
| 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 55 | A | 
| 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 56 | B | 
| 67041 | 57 | theories | 
| 67042 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 58 | C | 
| 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 59 | D*) | 
| 67041 | 60 | document_files | 
| 61 | "root.tex" | |
| 67042 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 62 | """) | 
| 67041 | 63 | |
| 64 | ||
| 65 | /* document directory */ | |
| 66 | ||
| 67042 
677cab7c2b85
adapted to changed ROOT syntax (see 13857f49d215);
 wenzelm parents: 
67041diff
changeset | 67 |     {
 | 
| 67041 | 68 |       progress.echo("  creating " + root_tex)
 | 
| 69 | ||
| 72375 | 70 | Isabelle_System.make_directory(root_tex.dir) | 
| 67041 | 71 | |
| 72 | File.write(root_tex, | |
| 73 | """\documentclass[11pt,a4paper]{article}
 | |
| 73404 | 74 | \""" + """usepackage[T1]{fontenc}
 | 
| 67041 | 75 | \""" + """usepackage{isabelle,isabellesym}
 | 
| 76 | ||
| 77 | % further packages required for unusual symbols (see also | |
| 78 | % isabellesym.sty), use only when needed | |
| 79 | ||
| 80 | %\""" + """usepackage{amssymb}
 | |
| 81 | %for \<leadsto>, \<box>, \<diamond>, \<sqsupset>, \<mho>, \<Join>, | |
| 82 | %\<lhd>, \<lesssim>, \<greatersim>, \<lessapprox>, \<greaterapprox>, | |
| 83 | %\<triangleq>, \<yen>, \<lozenge> | |
| 84 | ||
| 85 | %\""" + """usepackage{eurosym}
 | |
| 86 | %for \<euro> | |
| 87 | ||
| 73467 
090add96f5f9
more glyphs proposed by Simon Foster: 0x002713, 0x002717, 0x002af4, 0x002afb, 0x002afd;
 wenzelm parents: 
73446diff
changeset | 88 | %\""" + """usepackage[only,bigsqcap,fatsemi,interleave,sslash]{stmaryrd}
 | 
| 73446 
d1c4c2395650
more Isabelle symbol definitions for Z Notation, based on https://github.com/isabelle-utp/Z_Toolkit 998c9f7880d3 by Simon Foster;
 wenzelm parents: 
73404diff
changeset | 89 | %for \<Sqinter>, \<Zsemi> | 
| 67041 | 90 | |
| 91 | %\""" + """usepackage{eufrak}
 | |
| 92 | %for \<AA> ... \<ZZ>, \<aa> ... \<zz> (also included in amssymb) | |
| 93 | ||
| 94 | %\""" + """usepackage{textcomp}
 | |
| 95 | %for \<onequarter>, \<onehalf>, \<threequarters>, \<degree>, \<cent>, | |
| 96 | %\<currency> | |
| 97 | ||
| 98 | % this should be the last package used | |
| 99 | \""" + """usepackage{pdfsetup}
 | |
| 100 | ||
| 101 | % urls in roman style, theory text in math-similar italics | |
| 102 | \""" + """urlstyle{rm}
 | |
| 103 | \isabellestyle{it}
 | |
| 104 | ||
| 105 | % for uniform font size | |
| 106 | %\renewcommand{\isastyle}{\isastyleminor}
 | |
| 107 | ||
| 108 | ||
| 109 | \begin{document}
 | |
| 110 | ||
| 111 | \title{""" + (proper_string(title) getOrElse latex_name(name)) + """}
 | |
| 67043 | 112 | \author{""" + (proper_string(author) getOrElse latex_name(System.getProperty("user.name"))) + """}
 | 
| 67041 | 113 | \maketitle | 
| 114 | ||
| 115 | \tableofcontents | |
| 116 | ||
| 117 | % sane default for proof documents | |
| 118 | \parindent 0pt\parskip 0.5ex | |
| 119 | ||
| 120 | % generated text of all theories | |
| 121 | \input{session}
 | |
| 122 | ||
| 123 | % optional bibliography | |
| 124 | %\bibliographystyle{abbrv}
 | |
| 125 | %\bibliography{root}
 | |
| 126 | ||
| 127 | \end{document}
 | |
| 128 | ||
| 129 | %%% Local Variables: | |
| 130 | %%% mode: latex | |
| 131 | %%% TeX-master: t | |
| 132 | %%% End: | |
| 133 | """) | |
| 134 | } | |
| 135 | ||
| 136 | ||
| 67069 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 137 | /* Mercurial repository */ | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 138 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 139 |     if (init_repos) {
 | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 140 |       progress.echo("  \nInitializing Mercurial repository " + session_dir)
 | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 141 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 142 | val hg = Mercurial.init_repository(session_dir) | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 143 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 144 |       val hg_ignore = session_dir + Path.explode(".hgignore")
 | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 145 | File.write(hg_ignore, | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 146 | """syntax: glob | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 147 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 148 | *~ | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 149 | *.marks | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 150 | *.orig | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 151 | *.rej | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 152 | .DS_Store | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 153 | .swp | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 154 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 155 | syntax: regexp | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 156 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 157 | ^output/ | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 158 | """) | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 159 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 160 | hg.add(List(root_path, root_tex, hg_ignore)) | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 161 | } | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 162 | |
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 163 | |
| 67041 | 164 | /* notes */ | 
| 165 | ||
| 166 |     {
 | |
| 167 | val print_dir = session_dir.implode | |
| 168 |       progress.echo("""
 | |
| 169 | Now use the following command line to build the session: | |
| 170 | ||
| 171 | isabelle build -D """ + | |
| 172 | (if (Bash.string(print_dir) == print_dir) print_dir else quote(print_dir)) + "\n") | |
| 173 | } | |
| 174 | } | |
| 175 | ||
| 176 | ||
| 177 | ||
| 178 | /** Isabelle tool wrapper **/ | |
| 179 | ||
| 72763 | 180 |   val isabelle_tool = Isabelle_Tool("mkroot", "prepare session root directory",
 | 
| 181 | Scala_Project.here, args => | |
| 67041 | 182 |   {
 | 
| 67043 | 183 | var author = "" | 
| 67069 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 184 | var init_repos = false | 
| 67043 | 185 | var title = "" | 
| 67041 | 186 | var session_name = "" | 
| 187 | ||
| 188 |     val getopts = Getopts("""
 | |
| 67043 | 189 | Usage: isabelle mkroot [OPTIONS] [DIRECTORY] | 
| 67041 | 190 | |
| 191 | Options are: | |
| 67043 | 192 | -A LATEX provide author in LaTeX notation (default: user name) | 
| 67069 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 193 | -I init Mercurial repository and add generated files | 
| 67043 | 194 | -T LATEX provide title in LaTeX notation (default: session name) | 
| 195 | -n NAME alternative session name (default: directory base name) | |
| 67041 | 196 | |
| 67043 | 197 | Prepare session root directory (default: current directory). | 
| 67041 | 198 | """, | 
| 67043 | 199 | "A:" -> (arg => author = arg), | 
| 67069 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 200 | "I" -> (arg => init_repos = true), | 
| 67043 | 201 | "T:" -> (arg => title = arg), | 
| 67041 | 202 | "n:" -> (arg => session_name = arg)) | 
| 203 | ||
| 204 | val more_args = getopts(args) | |
| 205 | ||
| 206 | val session_dir = | |
| 207 |       more_args match {
 | |
| 208 | case Nil => Path.current | |
| 209 | case List(dir) => Path.explode(dir) | |
| 210 | case _ => getopts.usage() | |
| 211 | } | |
| 212 | ||
| 67069 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 213 | mkroot(session_name = session_name, session_dir = session_dir, init_repos = init_repos, | 
| 
f11486d31586
init Mercurial repository for the generated session files;
 wenzelm parents: 
67043diff
changeset | 214 | author = author, title = title, progress = new Console_Progress) | 
| 67041 | 215 | }) | 
| 216 | } |