diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/ChangeLog | 7 | ||||
| -rw-r--r-- | src/doc.c | 4 | ||||
| -rw-r--r-- | src/keyboard.c | 23 | ||||
| -rw-r--r-- | src/keymap.c | 45 | 
4 files changed, 49 insertions, 30 deletions
| diff --git a/src/ChangeLog b/src/ChangeLog index 0914d8efac0..bfb9b1a4c83 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,10 @@ +2013-06-05  Stefan Monnier  <monnier@iro.umontreal.ca> + +	* keymap.c (Fcurrent_active_maps, Fdescribe_buffer_bindings): +	* keyboard.c (menu_bar_items, tool_bar_items): +	* doc.c (Fsubstitute_command_keys): Voverriding_terminal_local_map does +	not override local keymaps any more. +  2013-06-04  Eli Zaretskii  <eliz@gnu.org>  	* window.c (Fpos_visible_in_window_p): Doc fix.  (Bug#14540) diff --git a/src/doc.c b/src/doc.c index e45481944f0..155a9891303 100644 --- a/src/doc.c +++ b/src/doc.c @@ -758,9 +758,7 @@ Otherwise, return a new string, without any text properties.  */)       or a specified local map (which means search just that and the       global map).  If non-nil, it might come from Voverriding_local_map,       or from a \\<mapname> construct in STRING itself..  */ -  keymap = KVAR (current_kboard, Voverriding_terminal_local_map); -  if (NILP (keymap)) -    keymap = Voverriding_local_map; +  keymap = Voverriding_local_map;    bsize = SBYTES (string);    bufp = buf = xmalloc (bsize); diff --git a/src/keyboard.c b/src/keyboard.c index 8dd109d252d..d01ecb9432b 100644 --- a/src/keyboard.c +++ b/src/keyboard.c @@ -7392,7 +7392,8 @@ menu_bar_items (Lisp_Object old)      Lisp_Object *tmaps;      /* Should overriding-terminal-local-map and overriding-local-map apply?  */ -    if (!NILP (Voverriding_local_map_menu_flag)) +    if (!NILP (Voverriding_local_map_menu_flag) +	&& !NILP (Voverriding_local_map))        {  	/* Yes, use them (if non-nil) as well as the global map.  */  	maps = alloca (3 * sizeof (maps[0])); @@ -7412,8 +7413,11 @@ menu_bar_items (Lisp_Object old)  	Lisp_Object tem;  	ptrdiff_t nminor;  	nminor = current_minor_maps (NULL, &tmaps); -	maps = alloca ((nminor + 3) * sizeof *maps); +	maps = alloca ((nminor + 4) * sizeof *maps);  	nmaps = 0; +	tem = KVAR (current_kboard, Voverriding_terminal_local_map); +	if (!NILP (tem) && !NILP (Voverriding_local_map_menu_flag)) +	  maps[nmaps++] = tem;  	if (tem = get_local_map (PT, current_buffer, Qkeymap), !NILP (tem))  	  maps[nmaps++] = tem;  	memcpy (maps + nmaps, tmaps, nminor * sizeof (maps[0])); @@ -7938,7 +7942,8 @@ tool_bar_items (Lisp_Object reuse, int *nitems)       to process.  */    /* Should overriding-terminal-local-map and overriding-local-map apply?  */ -  if (!NILP (Voverriding_local_map_menu_flag)) +  if (!NILP (Voverriding_local_map_menu_flag) +      && !NILP (Voverriding_local_map))      {        /* Yes, use them (if non-nil) as well as the global map.  */        maps = alloca (3 * sizeof *maps); @@ -7958,8 +7963,11 @@ tool_bar_items (Lisp_Object reuse, int *nitems)        Lisp_Object tem;        ptrdiff_t nminor;        nminor = current_minor_maps (NULL, &tmaps); -      maps = alloca ((nminor + 3) * sizeof *maps); +      maps = alloca ((nminor + 4) * sizeof *maps);        nmaps = 0; +      tem = KVAR (current_kboard, Voverriding_terminal_local_map); +      if (!NILP (tem) && !NILP (Voverriding_local_map_menu_flag)) +	maps[nmaps++] = tem;        if (tem = get_local_map (PT, current_buffer, Qkeymap), !NILP (tem))  	maps[nmaps++] = tem;        memcpy (maps + nmaps, tmaps, nminor * sizeof (maps[0])); @@ -11443,10 +11451,7 @@ tool-bar separators natively.  Otherwise it is unused (e.g. on GTK).  */);    DEFVAR_KBOARD ("overriding-terminal-local-map",  		 Voverriding_terminal_local_map, -		 doc: /* Per-terminal keymap that overrides all other local keymaps. -If this variable is non-nil, it is used as a keymap instead of the -buffer's local map, and the minor mode keymaps and text property keymaps. -It also replaces `overriding-local-map'. +		 doc: /* Per-terminal keymap that takes precedence over all other keymaps.  This variable is intended to let commands such as `universal-argument'  set up a different keymap for reading the next command. @@ -11456,7 +11461,7 @@ terminal device.  See Info node `(elisp)Multiple Terminals'.  */);    DEFVAR_LISP ("overriding-local-map", Voverriding_local_map, -	       doc: /* Keymap that overrides all other local keymaps. +	       doc: /* Keymap that overrides almost all other local keymaps.  If this variable is non-nil, it is used as a keymap--replacing the  buffer's local map, the minor mode keymaps, and char property keymaps.  */);    Voverriding_local_map = Qnil; diff --git a/src/keymap.c b/src/keymap.c index c43d528b25b..536db77f59b 100644 --- a/src/keymap.c +++ b/src/keymap.c @@ -56,28 +56,28 @@ along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.  */  #include "keymap.h"  #include "window.h" -/* Actually allocate storage for these variables */ +/* Actually allocate storage for these variables.  */ -Lisp_Object current_global_map;	/* Current global keymap */ +Lisp_Object current_global_map;	/* Current global keymap.  */ -Lisp_Object global_map;		/* default global key bindings */ +Lisp_Object global_map;		/* Default global key bindings.  */  Lisp_Object meta_map;		/* The keymap used for globally bound -				   ESC-prefixed default commands */ +				   ESC-prefixed default commands.  */  Lisp_Object control_x_map;	/* The keymap used for globally bound -				   C-x-prefixed default commands */ +				   C-x-prefixed default commands.  */  				/* The keymap used by the minibuf for local  				   bindings when spaces are allowed in the -				   minibuf */ +				   minibuf.  */  				/* The keymap used by the minibuf for local  				   bindings when spaces are not encouraged -				   in the minibuf */ +				   in the minibuf.  */ -/* keymap used for minibuffers when doing completion */ -/* keymap used for minibuffers when doing completion and require a match */ +/* Keymap used for minibuffers when doing completion.  */ +/* Keymap used for minibuffers when doing completion and require a match.  */  static Lisp_Object Qkeymapp, Qnon_ascii;  Lisp_Object Qkeymap, Qmenu_item, Qremap;  static Lisp_Object QCadvertised_binding; @@ -1571,17 +1571,14 @@ like in the respective argument of `key-binding'.  */)  	}      } -  if (!NILP (olp)) -    { -      if (!NILP (KVAR (current_kboard, Voverriding_terminal_local_map))) -	keymaps = Fcons (KVAR (current_kboard, Voverriding_terminal_local_map), -			 keymaps); +  if (!NILP (olp)        /* The doc said that overriding-terminal-local-map should  	 override overriding-local-map.  The code used them both,  	 but it seems clearer to use just one.  rms, jan 2005.  */ -      else if (!NILP (Voverriding_local_map)) -	keymaps = Fcons (Voverriding_local_map, keymaps); -    } +      && NILP (KVAR (current_kboard, Voverriding_terminal_local_map)) +      && !NILP (Voverriding_local_map)) +    keymaps = Fcons (Voverriding_local_map, keymaps); +    if (NILP (XCDR (keymaps)))      {        Lisp_Object *maps; @@ -1592,6 +1589,7 @@ like in the respective argument of `key-binding'.  */)        Lisp_Object local_map = get_local_map (pt, current_buffer, Qlocal_map);        /* This returns nil unless there is a `keymap' property.  */        Lisp_Object keymap = get_local_map (pt, current_buffer, Qkeymap); +      Lisp_Object otlp = KVAR (current_kboard, Voverriding_terminal_local_map);        if (CONSP (position))  	{ @@ -1656,6 +1654,9 @@ like in the respective argument of `key-binding'.  */)        if (!NILP (keymap))  	keymaps = Fcons (keymap, keymaps); + +      if (!NILP (olp) && !NILP (otlp)) +	keymaps = Fcons (otlp, keymaps);      }    unbind_to (count, Qnil); @@ -2851,7 +2852,7 @@ You type        Translation\n\  	    insert ("\n", 1); -	    /* Insert calls signal_after_change which may GC. */ +	    /* Insert calls signal_after_change which may GC.  */  	    translate = SDATA (KVAR (current_kboard, Vkeyboard_translate_table));  	  } @@ -2867,6 +2868,14 @@ You type        Translation\n\    start1 = Qnil;    if (!NILP (KVAR (current_kboard, Voverriding_terminal_local_map)))      start1 = KVAR (current_kboard, Voverriding_terminal_local_map); + +  if (!NILP (start1)) +    { +      describe_map_tree (start1, 1, shadow, prefix, +			 "\f\nOverriding Bindings", nomenu, 0, 0, 0); +      shadow = Fcons (start1, shadow); +      start1 = Qnil; +    }    else if (!NILP (Voverriding_local_map))      start1 = Voverriding_local_map; | 
