Ar an naoú lá is fiche de mí Méan Fómhair, scríobh Aidan Kehoe: 
 
  Ar an t-ochtú lá is fiche de mí Méan Fómhair, scríobh Robert Pluim: 
 
  > [...] What can I get you to help debug this?
 
 The report should be plenty, I can reproduce. Will look into it this
 weekend. 
A little later than promised, I’m afraid, but done now. Thank you for the
report, it’s something I really should have caught myself, but if you don’t use
functionality yourself, it’s always a risk. 
# HG changeset patch
# User Aidan Kehoe <kehoea(a)parhasard.net>
# Date 1350249039 -3600
# Node ID 7371081ce8f743a2fcd6651b77b5236d4cb05f16
# Parent  b6c506c30f93e8b9f06c6b9e5d6d0dcc9cd3f5c3
Have command remapping work interactively too, thank you Robert Pluim!
src/ChangeLog addition:
2012-10-14  Aidan Kehoe  <kehoea(a)parhasard.net>
	Have command remapping work interactively too, thank you Robert
	Pluim.
	* event-stream.c (Fdispatch_event):
	Obey command remapping here, it wasn't done for us.
	* keymap.c:
	* keymap.c (command_remapping_for_event): New, needed to observe
	command remapping interactively.
	* lisp.h: Make it available.
lisp/ChangeLog addition:
2012-10-14  Aidan Kehoe  <kehoea(a)parhasard.net>
	* help.el:
	* help.el (describe-function-1):
	Add some newlines here when dealing with remapped commands, thank
	you Robert Pluim.
diff -r b6c506c30f93 -r 7371081ce8f7 lisp/ChangeLog
--- a/lisp/ChangeLog	Sun Oct 14 16:14:25 2012 +0100
+++ b/lisp/ChangeLog	Sun Oct 14 22:10:39 2012 +0100
@@ -1,3 +1,10 @@
+2012-10-14  Aidan Kehoe  <kehoea(a)parhasard.net>
+
+	* help.el:
+	* help.el (describe-function-1):
+	Add some newlines here when dealing with remapped commands, thank
+	you Robert Pluim.
+
 2012-10-13  Mats Lidell  <matsl(a)xemacs.org>
 
 	* process.el (call-process-shell-command): New function from GNU.
diff -r b6c506c30f93 -r 7371081ce8f7 lisp/help.el
--- a/lisp/help.el	Sun Oct 14 16:14:25 2012 +0100
+++ b/lisp/help.el	Sun Oct 14 22:10:39 2012 +0100
@@ -1544,10 +1544,10 @@
                                    (format "\n\\[%s]" function))))
                        (when commands-remapped-to
                          (if (cdr commands-remapped-to)
-                             (princ (format "The following functions are \
+                             (princ (format "\n\nThe following functions are \
 remapped to it:\n`%s'" (mapconcat #'prin1-to-string commands-remapped-to
                                   "', `")))
-                           (princ (format "`%s' is remapped to it.\n"
+                           (princ (format "\n\n`%s' is remapped to it.\n"
                                           (car
                                            commands-remapped-to))))))))))))))
 
diff -r b6c506c30f93 -r 7371081ce8f7 src/ChangeLog
--- a/src/ChangeLog	Sun Oct 14 16:14:25 2012 +0100
+++ b/src/ChangeLog	Sun Oct 14 22:10:39 2012 +0100
@@ -1,3 +1,14 @@
+2012-10-14  Aidan Kehoe  <kehoea(a)parhasard.net>
+
+	Have command remapping work interactively too, thank you Robert
+	Pluim.
+	* event-stream.c (Fdispatch_event):
+	Obey command remapping here, it wasn't done for us.
+	* keymap.c:
+	* keymap.c (command_remapping_for_event): New, needed to observe
+	command remapping interactively.
+	* lisp.h: Make it available.
+
 2012-10-14  Aidan Kehoe  <kehoea(a)parhasard.net>
 
 	Respect face and display table information in the minibuffer
diff -r b6c506c30f93 -r 7371081ce8f7 src/event-stream.c
--- a/src/event-stream.c	Sun Oct 14 16:14:25 2012 +0100
+++ b/src/event-stream.c	Sun Oct 14 22:10:39 2012 +0100
@@ -4550,8 +4550,6 @@
 	    int magic_undo = 0;
 	    Elemcount magic_undo_count = 20;
 
-	    Vthis_command = leaf;
-
 	    /* Don't push an undo boundary if the command set the prefix arg,
 	       or if we are executing a keyboard macro, or if in the
 	       minibuffer.  If the command we are about to execute is
@@ -4567,6 +4565,8 @@
 	    if (SYMBOLP (leaf))
 	      {
 		Lisp_Object prop = Fget (leaf, Qself_insert_defer_undo, Qnil);
+                Lisp_Object remap = Qnil;
+
 		if (NATNUMP (prop))
                   {
                     magic_undo = 1;
@@ -4587,8 +4587,16 @@
 		  magic_undo = 1;
 		else if (EQ (leaf, Qself_insert_command))
 		  magic_undo = 1;
+
+                remap = command_remapping_for_event (leaf, event);
+                if (!NILP (remap))
+                  {
+                    leaf = remap;
+                  }
 	      }
 
+	    Vthis_command = leaf;
+
 	    if (!magic_undo)
 	      command_builder->self_insert_countdown = 0;
 	    if (NILP (XCONSOLE (console)->prefix_arg)
diff -r b6c506c30f93 -r 7371081ce8f7 src/keymap.c
--- a/src/keymap.c	Sun Oct 14 16:14:25 2012 +0100
+++ b/src/keymap.c	Sun Oct 14 22:10:39 2012 +0100
@@ -2127,6 +2127,20 @@
   return Qnil;
 }
 
+Lisp_Object
+command_remapping_for_event (Lisp_Object command, Lisp_Object event0)
+{
+  /* This function can GC */
+  Lisp_Object maps[100];
+  int nmaps;
+
+  nmaps = get_relevant_keymaps (event0, Qnil, countof (maps), maps);
+  if (nmaps > countof (maps))
+    nmaps = countof (maps);
+
+  return command_remapping (command, nmaps, maps);
+}                             
+
 DEFUN ("command-remapping", Fcommand_remapping, 1, 3, 0, /*
 Return the remapping for command COMMAND.
 
diff -r b6c506c30f93 -r 7371081ce8f7 src/lisp.h
--- a/src/lisp.h	Sun Oct 14 16:14:25 2012 +0100
+++ b/src/lisp.h	Sun Oct 14 22:10:39 2012 +0100
@@ -5473,6 +5473,9 @@
 EXFUN (Fmake_sparse_keymap, 1);
 EXFUN (Fset_keymap_parents, 2);
 
+Lisp_Object command_remapping_for_event (Lisp_Object command,
+                                         Lisp_Object event0);
+
 void where_is_to_char (Lisp_Object, Eistring *);
 
 /* Defined in lread.c */
-- 
‘Liston operated so fast that he once accidentally amputated an assistant’s 
fingers along with a patient’s leg, […] The patient and the assistant both 
died of sepsis, and a spectator reportedly died of shock, resulting in the 
only known procedure with a 300% mortality.’ (Atul Gawande, NEJM, 2012)
_______________________________________________
XEmacs-Patches mailing list
XEmacs-Patches(a)xemacs.org
http://lists.xemacs.org/mailman/listinfo/xemacs-patches