| author | wenzelm | 
| Tue, 08 Feb 2011 19:53:35 +0100 | |
| changeset 41730 | 14ed42540d22 | 
| parent 40533 | e38e80686ce5 | 
| child 43411 | 0206466ee473 | 
| permissions | -rw-r--r-- | 
| 34166 | 1 | /* Title: Pure/Isar/outer_syntax.scala | 
| 2 | Author: Makarius | |
| 3 | ||
| 4 | Isabelle/Isar outer syntax. | |
| 5 | */ | |
| 6 | ||
| 7 | package isabelle | |
| 8 | ||
| 9 | ||
| 10 | import scala.util.parsing.input.{Reader, CharSequenceReader}
 | |
| 11 | ||
| 12 | ||
| 13 | class Outer_Syntax(symbols: Symbol.Interpretation) | |
| 14 | {
 | |
| 36947 | 15 |   protected val keywords: Map[String, String] = Map((";" -> Keyword.DIAG))
 | 
| 34166 | 16 | protected val lexicon: Scan.Lexicon = Scan.Lexicon.empty | 
| 17 | lazy val completion: Completion = new Completion + symbols // FIXME !? | |
| 18 | ||
| 38471 
0924654b8163
report command token name instead of kind, which can be retrieved later via Outer_Syntax.keyword_kind;
 wenzelm parents: 
36956diff
changeset | 19 | def keyword_kind(name: String): Option[String] = keywords.get(name) | 
| 
0924654b8163
report command token name instead of kind, which can be retrieved later via Outer_Syntax.keyword_kind;
 wenzelm parents: 
36956diff
changeset | 20 | |
| 40533 
e38e80686ce5
somewhat adhoc replacement for 'thus' and 'hence';
 wenzelm parents: 
40459diff
changeset | 21 | def + (name: String, kind: String, replace: String): Outer_Syntax = | 
| 34166 | 22 |   {
 | 
| 23 | val new_keywords = keywords + (name -> kind) | |
| 24 | val new_lexicon = lexicon + name | |
| 40533 
e38e80686ce5
somewhat adhoc replacement for 'thus' and 'hence';
 wenzelm parents: 
40459diff
changeset | 25 | val new_completion = completion + (name, replace) | 
| 34166 | 26 |     new Outer_Syntax(symbols) {
 | 
| 27 | override val lexicon = new_lexicon | |
| 28 | override val keywords = new_keywords | |
| 29 | override lazy val completion = new_completion | |
| 30 | } | |
| 31 | } | |
| 32 | ||
| 40533 
e38e80686ce5
somewhat adhoc replacement for 'thus' and 'hence';
 wenzelm parents: 
40459diff
changeset | 33 | def + (name: String, kind: String): Outer_Syntax = this + (name, kind, name) | 
| 
e38e80686ce5
somewhat adhoc replacement for 'thus' and 'hence';
 wenzelm parents: 
40459diff
changeset | 34 | |
| 36947 | 35 | def + (name: String): Outer_Syntax = this + (name, Keyword.MINOR) | 
| 34166 | 36 | |
| 37 | def is_command(name: String): Boolean = | |
| 40458 
12c8c64203b3
treat main theory commands like headings, and nest anything else inside;
 wenzelm parents: 
40455diff
changeset | 38 |     keyword_kind(name) match {
 | 
| 36947 | 39 | case Some(kind) => kind != Keyword.MINOR | 
| 34166 | 40 | case None => false | 
| 41 | } | |
| 42 | ||
| 40454 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 43 | def heading_level(name: String): Option[Int] = | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 44 |     name match {
 | 
| 40458 
12c8c64203b3
treat main theory commands like headings, and nest anything else inside;
 wenzelm parents: 
40455diff
changeset | 45 | // FIXME avoid hard-wired info!? | 
| 40454 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 46 | case "header" => Some(1) | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 47 | case "chapter" => Some(2) | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 48 | case "section" | "sect" => Some(3) | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 49 | case "subsection" | "subsect" => Some(4) | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 50 | case "subsubsection" | "subsubsect" => Some(5) | 
| 40458 
12c8c64203b3
treat main theory commands like headings, and nest anything else inside;
 wenzelm parents: 
40455diff
changeset | 51 | case _ => | 
| 
12c8c64203b3
treat main theory commands like headings, and nest anything else inside;
 wenzelm parents: 
40455diff
changeset | 52 |         keyword_kind(name) match {
 | 
| 
12c8c64203b3
treat main theory commands like headings, and nest anything else inside;
 wenzelm parents: 
40455diff
changeset | 53 | case Some(kind) if Keyword.theory(kind) => Some(6) | 
| 
12c8c64203b3
treat main theory commands like headings, and nest anything else inside;
 wenzelm parents: 
40455diff
changeset | 54 | case _ => None | 
| 
12c8c64203b3
treat main theory commands like headings, and nest anything else inside;
 wenzelm parents: 
40455diff
changeset | 55 | } | 
| 40454 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 56 | } | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 57 | |
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 58 | def heading_level(command: Command): Option[Int] = | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 59 | heading_level(command.name) | 
| 
2516ea25a54b
some support for nested source structure, based on section headings;
 wenzelm parents: 
38471diff
changeset | 60 | |
| 34166 | 61 | |
| 62 | /* tokenize */ | |
| 63 | ||
| 36956 
21be4832c362
renamed class Outer_Lex to Token and Token_Kind to Token.Kind;
 wenzelm parents: 
36947diff
changeset | 64 | def scan(input: Reader[Char]): List[Token] = | 
| 34166 | 65 |   {
 | 
| 66 | import lexicon._ | |
| 67 | ||
| 68 |     parseAll(rep(token(symbols, is_command)), input) match {
 | |
| 69 | case Success(tokens, _) => tokens | |
| 34264 | 70 |       case _ => error("Unexpected failure of tokenizing input:\n" + input.source.toString)
 | 
| 34166 | 71 | } | 
| 72 | } | |
| 73 | ||
| 36956 
21be4832c362
renamed class Outer_Lex to Token and Token_Kind to Token.Kind;
 wenzelm parents: 
36947diff
changeset | 74 | def scan(input: CharSequence): List[Token] = | 
| 34166 | 75 | scan(new CharSequenceReader(input)) | 
| 76 | } |