changeset 23734:44546fc7faad

(Fsingle_key_description): Handle generic characters.
author Richard M. Stallman <rms@gnu.org>
date Thu, 19 Nov 1998 04:30:14 +0000 (1998-11-19)
parents e963fc8ca03f
children 9392dd2e6137
files src/keymap.c
diffstat 1 files changed, 24 insertions(+), 5 deletions(-) [+]
line wrap: on
line diff
--- a/src/keymap.c	Thu Nov 19 04:26:44 1998 +0000
+++ b/src/keymap.c	Thu Nov 19 04:30:14 1998 +0000
@@ -1840,7 +1840,6 @@
     {
       unsigned char work[4], *str;
       int i = CHAR_STRING (c, work, str);
-
       bcopy (str, p, i);
       p += i;
     }
@@ -1856,14 +1855,34 @@
   (key)
      Lisp_Object key;
 {
-  char tem[20];
-
   key = EVENT_HEAD (key);
 
   if (INTEGERP (key))		/* Normal character */
     {
-      *push_key_description (XUINT (key), tem) = 0;
-      return build_string (tem);
+      unsigned int charset, c1, c2;
+
+      if (SINGLE_BYTE_CHAR_P (XINT (key)))
+	charset = 0;
+      else
+	SPLIT_NON_ASCII_CHAR (XINT (key), charset, c1, c2);
+
+      if (charset
+	  && ((c1 >= 0 && c1 < 32)
+	      || (c2 >= 0 && c2 < 32)))
+	{
+	  /* Handle a generic character.  */
+	  Lisp_Object name;
+	  name = CHARSET_TABLE_INFO (charset, CHARSET_LONG_NAME_IDX);
+	  CHECK_STRING (name, 0);
+	  return concat2 (build_string ("Character set "), name);
+	}
+      else
+	{
+	  char tem[20];
+
+	  *push_key_description (XUINT (key), tem) = 0;
+	  return build_string (tem);
+	}
     }
   else if (SYMBOLP (key))	/* Function key or event-symbol */
     return Fsymbol_name (key);