prefer Symbol.decode_strict in batch mode, to avoid files with spurious Unicode symbols that clash with Isabelle symbol interpretation;
authorwenzelm
Fri, 30 Nov 2012 10:42:54 +0100
changeset 50291 674893679352
parent 50290 735bea8d89c9
child 50292 45fe12c9788e
prefer Symbol.decode_strict in batch mode, to avoid files with spurious Unicode symbols that clash with Isabelle symbol interpretation;
src/Pure/General/symbol.scala
src/Pure/Thy/thy_load.scala
--- a/src/Pure/General/symbol.scala	Thu Nov 29 23:12:50 2012 +0100
+++ b/src/Pure/General/symbol.scala	Fri Nov 30 10:42:54 2012 +0100
@@ -380,6 +380,18 @@
   def decode(text: String): String = symbols.decode(text)
   def encode(text: String): String = symbols.encode(text)
 
+  def decode_strict(text: String): String =
+  {
+    val decoded = decode(text)
+    if (encode(decoded) == text) decoded
+    else {
+      val bad = new mutable.ListBuffer[Symbol]
+      for (s <- iterator(text) if encode(decode(s)) != s && !bad.contains(s))
+        bad += s
+      error("Bad Unicode symbols in text: " + commas_quote(bad))
+    }
+  }
+
   def fonts: Map[Symbol, String] = symbols.fonts
   def font_names: List[String] = symbols.font_names
   def font_index: Map[String, Int] = symbols.font_index
--- a/src/Pure/Thy/thy_load.scala	Thu Nov 29 23:12:50 2012 +0100
+++ b/src/Pure/Thy/thy_load.scala	Fri Nov 30 10:42:54 2012 +0100
@@ -47,7 +47,10 @@
   {
     val path = Path.explode(name.node)
     if (!path.is_file) error("No such file: " + path.toString)
-    f(File.read(path))
+
+    val text = File.read(path)
+    Symbol.decode_strict(text)
+    f(text)
   }