improved is_letter etc.;
authorwenzelm
Thu, 12 Feb 1998 12:35:50 +0100
changeset 4616 d257e6c6614f
parent 4615 67457d16cdbc
child 4617 cea2a5b5ee10
improved is_letter etc.;
src/Pure/library.ML
--- a/src/Pure/library.ML	Tue Feb 10 10:27:30 1998 +0100
+++ b/src/Pure/library.ML	Thu Feb 12 12:35:50 1998 +0100
@@ -374,11 +374,12 @@
 (** strings **)
 
 fun is_letter ch =
-  ord "A" <= ord ch andalso ord ch <= ord "Z" orelse
-  ord "a" <= ord ch andalso ord ch <= ord "z";
+  size ch = 1 andalso
+   (ord "A" <= ord ch andalso ord ch <= ord "Z" orelse
+    ord "a" <= ord ch andalso ord ch <= ord "z");
 
 fun is_digit ch =
-  ord "0" <= ord ch andalso ord ch <= ord "9";
+  size ch = 1 andalso ord "0" <= ord ch andalso ord ch <= ord "9";
 
 (*letter or _ or prime (')*)
 fun is_quasi_letter "_" = true
@@ -393,13 +394,13 @@
 val is_letdig = is_quasi_letter orf is_digit;
 
 (*printable chars*)
-fun is_printable c = ord c > ord " " andalso ord c <= ord "~";
+fun is_printable c = size c = 1 andalso ord c > ord " " andalso ord c <= ord "~";
 
 (*lower all chars of string*)
 val to_lower =
   let
     fun lower ch =
-      if ch >= "A" andalso ch <= "Z" then
+      if size ch = 1 andalso ch >= "A" andalso ch <= "Z" then
         chr (ord ch - ord "A" + ord "a")
       else ch;
   in implode o (map lower) o explode end;