GNU bug report logs - #34080
27.0.50, 26.1; undocumented key bindings for *vc-diff*

Previous Next

Package: emacs;

Reported by: Van L <van <at> scratch.space>

Date: Tue, 15 Jan 2019 05:31:01 UTC

Severity: wishlist

Found in version 27.0.50

Done: Sean Whitton <spwhitton <at> spwhitton.name>

Full log


View this message in rfc822 format

From: Sean Whitton <spwhitton <at> spwhitton.name>
To: Van L <van <at> scratch.space>,  34080 <at> debbugs.gnu.org,  Juri Linkov <juri <at> linkov.net>
Subject: bug#34080: 27.0.50, 26.1; undocumented key bindings for *vc-diff*
Date: Thu, 15 May 2025 16:46:57 +0100
Hello,

On Fri 25 Sep 2020 at 02:21pm +02, Lars Ingebrigtsen wrote:

> Van L <van <at> scratch.space> writes:
>
>> +;; List key bindings for describe-mode
>> +(put 'diff-hunk-next :advertised-binding [tab])
>> +(put 'diff-hunk-prev :advertised-binding [(shift tab)])
>> +
>
> I tried this patch, but `M-x describe-mode' in a *vc-diff* buffer did
> not seem to care that much -- it listed diff-hunk-prev on M-p and ESC
> <backtab> and -next on C-M-i/M-n only, with or without this patch.
>
> Is :advertised-binding not working here, or is ... er ... something else
> wrong?  The actual bindings are:
>
>     ("\t" . diff-hunk-next)
>     ([backtab] . diff-hunk-prev)

Searching the code base, :advertised-binding is meant to affect
where-is-internal, and only that function, I think.
But it does seem to be broken:

    (progn (put 'diff-hunk-next :advertised-binding "n") ; or '("n")
           (with-current-buffer "*vc-diff*"
             (mapcar #'key-description
                     (where-is-internal 'diff-hunk-next))))

    => ("TAB" "n" "C-M-i" "M-n" "<menu-bar> <diff> <Next Hunk>")

i.e. there is no prioritisation for the "n" binding.
Indeed, TAB comes first.

Then it seems like a separate issue why the "TAB" binding is not
appearing in 'M-x describe-mode'.  So there are two problems here.

-- 
Sean Whitton




This bug report was last modified 21 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.