# HG changeset patch # User Stefan Monnier # Date 1178552497 0 # Node ID f526513aec925c2d9ae3fb23c1ec922d282fbb7c # Parent d972fbe6be98448d6a8df6ee4d888dbc0311c73a (Fdefine_key, Flookup_key): Only do the 0x80->meta_modifier mapping for unibyte strings. diff -r d972fbe6be98 -r f526513aec92 src/ChangeLog --- a/src/ChangeLog Mon May 07 08:05:55 2007 +0000 +++ b/src/ChangeLog Mon May 07 15:41:37 2007 +0000 @@ -1,3 +1,8 @@ +2007-05-07 Stefan Monnier + + * keymap.c (Fdefine_key, Flookup_key): Only do the 0x80->meta_modifier + mapping for unibyte strings. + 2007-05-01 YAMAMOTO Mitsuharu * macmenu.c (mac_dialog_show): Apply 2007-04-27 change for xmenu.c. @@ -62,8 +67,8 @@ 2007-04-16 Chong Yidong - * dispnew.c (adjust_frame_glyphs_for_frame_redisplay): Set - garbaged flag in presence of window margins. + * dispnew.c (adjust_frame_glyphs_for_frame_redisplay): + Set garbaged flag in presence of window margins. (showing_window_margins_p): New function. * xdisp.c (cursor_row_p): Only end row on newline if it's a diff -r d972fbe6be98 -r f526513aec92 src/keymap.c --- a/src/keymap.c Mon May 07 08:05:55 2007 +0000 +++ b/src/keymap.c Mon May 07 15:41:37 2007 +0000 @@ -1156,7 +1156,8 @@ if (SYMBOLP (def) && !EQ (Vdefine_key_rebound_commands, Qt)) Vdefine_key_rebound_commands = Fcons (def, Vdefine_key_rebound_commands); - meta_bit = VECTORP (key) ? meta_modifier : 0x80; + meta_bit = (VECTORP (key) || STRINGP (key) && STRING_MULTIBYTE (key) + ? meta_modifier : 0x80); if (VECTORP (def) && ASIZE (def) > 0 && CONSP (AREF (def, 0))) { /* DEF is apparently an XEmacs-style keyboard macro. */ @@ -1312,7 +1313,7 @@ c = Fevent_convert_list (c); /* Turn the 8th bit of string chars into a meta modifier. */ - if (INTEGERP (c) && XINT (c) & 0x80 && STRINGP (key)) + if (STRINGP (key) && XINT (c) & 0x8 && !STRING_MULTIBYTE (key)) XSETINT (c, (XINT (c) | meta_modifier) & ~0x80); /* Allow string since binding for `menu-bar-select-buffer'