recovered markup for non-alphabetic keywords;
authorwenzelm
Fri, 17 Jun 2011 00:10:39 +0200
changeset 43418 c69e9fbb81a8
parent 43417 83be997a11d6
child 43419 6ed49c52d463
recovered markup for non-alphabetic keywords;
src/Pure/General/symbol.ML
src/Pure/General/symbol.scala
src/Pure/Isar/token.scala
src/Tools/jEdit/src/isabelle_markup.scala
--- a/src/Pure/General/symbol.ML	Thu Jun 16 23:35:37 2011 +0200
+++ b/src/Pure/General/symbol.ML	Fri Jun 17 00:10:39 2011 +0200
@@ -134,7 +134,7 @@
 fun malformed_msg s = "Malformed symbolic character: " ^ quote s;
 
 
-(* ascii symbols *)
+(* ASCII symbols *)
 
 fun is_ascii s = is_char s andalso ord s < 128;
 
--- a/src/Pure/General/symbol.scala	Thu Jun 16 23:35:37 2011 +0200
+++ b/src/Pure/General/symbol.scala	Fri Jun 17 00:10:39 2011 +0200
@@ -28,6 +28,19 @@
   }
 
 
+  /* ASCII characters */
+
+  def is_ascii_letter(c: Char): Boolean = 'A' <= c && c <= 'Z' || 'a' <= c && c <= 'z'
+  def is_ascii_digit(c: Char): Boolean = '0' <= c && c <= '9'
+  def is_ascii_quasi(c: Char): Boolean = c == '_' || c == '\''
+
+  def is_ascii_letdig(c: Char): Boolean =
+    is_ascii_letter(c) || is_ascii_digit(c) || is_ascii_quasi(c)
+
+  def is_ascii_identifier(s: String): Boolean =
+    s.length > 0 && is_ascii_letter(s(0)) && s.substring(1).forall(is_ascii_letdig)
+
+
   /* Symbol regexps */
 
   private val plain = new Regex("""(?xs)
--- a/src/Pure/Isar/token.scala	Thu Jun 16 23:35:37 2011 +0200
+++ b/src/Pure/Isar/token.scala	Fri Jun 17 00:10:39 2011 +0200
@@ -64,6 +64,7 @@
 sealed case class Token(val kind: Token.Kind.Value, val source: String)
 {
   def is_command: Boolean = kind == Token.Kind.COMMAND
+  def is_keyword: Boolean = kind == Token.Kind.KEYWORD
   def is_delimited: Boolean =
     kind == Token.Kind.STRING ||
     kind == Token.Kind.ALT_STRING ||
--- a/src/Tools/jEdit/src/isabelle_markup.scala	Thu Jun 16 23:35:37 2011 +0200
+++ b/src/Tools/jEdit/src/isabelle_markup.scala	Fri Jun 17 00:10:39 2011 +0200
@@ -215,5 +215,7 @@
   def token_markup(syntax: Outer_Syntax, token: Token): Byte =
     if (token.is_command)
       command_style(syntax.keyword_kind(token.content).getOrElse(""))
+    else if (token.is_keyword && !Symbol.is_ascii_identifier(token.content))
+      JEditToken.OPERATOR
     else token_style(token.kind)
 }