unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
* Fixing key bindings on some terminals
       [not found] <1659521050.517588.1401091680002.JavaMail.root@insa-lyon.fr>
@ 2014-05-26  8:32 ` Kevin Le Gouguec
  2014-05-26 15:18   ` Drew Adams
  0 siblings, 1 reply; 7+ messages in thread
From: Kevin Le Gouguec @ 2014-05-26  8:32 UTC (permalink / raw)
  To: help-gnu-emacs

Hi,

I'm running Emacs (23.2.1) in various terminals (Terminator 0.93, XTerm 261) and I'm trying to set the following behaviour:

(global-set-key (kbd "C-?") 'help-command)
(global-set-key (kbd "C-h") 'delete-backward-char)
(global-set-key (kbd "M-h") 'backward-kill-word)
(global-set-key (kbd "M-?") 'help)

I.e. move "help" to C-? so that I can use C-h to delete stuff backwards.

However with Terminator, C-? ends up behaving like C-h. Running "describe-key" and giving "C-?" as input gives information about the "DEL" key ; with XTerm, running "describe-key" and typing "C-?" prints the prompt in the minibuffer and waits for the final input, as expected.
I tried to test some other bindings like "C-," ; again, XTerm recognized the shortcut, while Terminator only recognized ",".

I know this is not really a problem with Emacs, but I'd like to know how I can pinpoint what application "eats" my shortcuts (is it Terminator, Openbox (3.5.0), something else entirely?). Basically I'm trying to get C-? to work with Terminator (I tried replacing Terminator with multi-term in Emacs but I'm still not satisfied with it). While I'd love it if anyone could provide a complete graph of causes and effects and the steps needed to get what I want, I'd still be glad with just a few pointers on what I need to learn/look for to fix how Emacs receives key presses when running inside Terminator.

Thanks in advance!



^ permalink raw reply	[flat|nested] 7+ messages in thread

* RE: Fixing key bindings on some terminals
  2014-05-26  8:32 ` Fixing key bindings on some terminals Kevin Le Gouguec
@ 2014-05-26 15:18   ` Drew Adams
  2014-05-26 15:50     ` Kevin Le Gouguec
  0 siblings, 1 reply; 7+ messages in thread
From: Drew Adams @ 2014-05-26 15:18 UTC (permalink / raw)
  To: Kevin Le Gouguec, help-gnu-emacs

> (global-set-key (kbd "C-?") 'help-command)
> (global-set-key (kbd "C-h") 'delete-backward-char)
...
> I.e. move "help" to C-? so that I can use C-h to delete stuff backwards.

See option `normal-erase-is-backspace' for this part, at least.



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: Fixing key bindings on some terminals
  2014-05-26 15:18   ` Drew Adams
@ 2014-05-26 15:50     ` Kevin Le Gouguec
  2014-05-26 18:32       ` Drew Adams
  0 siblings, 1 reply; 7+ messages in thread
From: Kevin Le Gouguec @ 2014-05-26 15:50 UTC (permalink / raw)
  To: Drew Adams; +Cc: help-gnu-emacs

Thanks, didn't know about that one!

This leaves getting C-? to work has "help-command" with Terminator. Right now it behaves like DEL or BACKSPACE, i.e. it deletes forward, since I set "normal-erase-is-backspace" to t.

To sum up, with "normal-erase-is-backspace" on:

- With Terminator, "describe-key" "C-?" returns "C-d".
- With XTerm, "describe-key" "C-?" prints "C-?-" and waits for completion.

I tried to dig some more and apparently this has to do with Terminator being an ASCII-based terminal, like gnome-terminal. I haven't read enough to know for sure, so right now I guess my options are:

a) digging real hard into Terminator to see how I can tell it to send C-<punctuation> when I type C-<punctuation> (if that's even possible)
b) switch completely to XTerm (find out how I can toggle fullscreen with Openbox) and find a way to split the window into many terminals, either
  (1) using screen (and finding a suitable shortcut to sacrifice as an escape key)
  (2) using Emacs's multi-term mode (and find a way to make it behave *exactly* like term-mode, instead of having its own little quirks)

Does anyone know anything about a) ? (I haven't found the Terminator community to be very reactive, at least not on launchpad)


----- Original Message -----
From: "Drew Adams" <drew.adams@oracle.com>
To: "Kevin Le Gouguec" <kevin.le-gouguec@insa-lyon.fr>, help-gnu-emacs@gnu.org
Sent: Monday, May 26, 2014 5:18:02 PM
Subject: RE: Fixing key bindings on some terminals

> (global-set-key (kbd "C-?") 'help-command)
> (global-set-key (kbd "C-h") 'delete-backward-char)
...
> I.e. move "help" to C-? so that I can use C-h to delete stuff backwards.

See option `normal-erase-is-backspace' for this part, at least.



^ permalink raw reply	[flat|nested] 7+ messages in thread

* RE: Fixing key bindings on some terminals
  2014-05-26 15:50     ` Kevin Le Gouguec
@ 2014-05-26 18:32       ` Drew Adams
  2014-05-26 20:14         ` Kevin Le Gouguec
  0 siblings, 1 reply; 7+ messages in thread
From: Drew Adams @ 2014-05-26 18:32 UTC (permalink / raw)
  To: Kevin Le Gouguec; +Cc: help-gnu-emacs

> > See option `normal-erase-is-backspace' for this part, at least.
>
> Thanks, didn't know about that one!
> 
> This leaves getting C-? to work has "help-command" with Terminator. Right
> now it behaves like DEL or BACKSPACE, i.e. it deletes forward, since I set
> "normal-erase-is-backspace" to t.

Actually, the *character* `CONTROL ?' (aka ^?, an ASCII control char)
*is* `DEL' (old name `DELETE').  And it is not the key `<backspace>',
the key `<delete>', or the key `C-?'.

That is (for the last part), it might be (and probably is) the case
that when you hold Control and hit `?', you keyboard does not send a
CONTROL ? character but something else.  Yes, this is confusing.

If you do `C-h k C-i', that is, hold Control and hit `i', Emacs always
writes `TAB'.  But the same does not happen for `C-?' (holding Control
and hitting `?').  Emacs distinguishes the character ^? (aka `DEL')
from the key that is sent from your keyboard when you hold Control and
hit `?'.

So `C-h k C-?' (holding Control and hitting `?') typically tells
you that "C-? is undefined".  It does not tell you that `DELL' is
bound to...

If you want `DEL') to invoke `help-command' then bind it to
`help-command':

(global-set-key (kbd "DEL") 'help-command)
(define-key help-map (kbd "DEL") 'help-for-help) ; for `DEL DEL'

Then you can use, for example, `DEL f' for `describe-function' and
`DEL DEL' for `help-for-help'.

You might need to bind `DEL' in additional keymaps also, as some
modes bind `DEL' to other commands.  For example, in Emacs Lisp
mode `DEL' is bound to `backward-delete-char-untabify'.

> To sum up, with "normal-erase-is-backspace" on:
> - With Terminator, "describe-key" "C-?" returns "C-d".
> - With XTerm, "describe-key" "C-?" prints "C-?-" and waits for completion.
> 
> I tried to dig some more and apparently this has to do with Terminator being
> an ASCII-based terminal, like gnome-terminal. I haven't read enough to know
> for sure, so right now I guess my options are:

Sorry, I know nothing about Terminator. 

An ASCII-based terminal should be able to handle `DEL'.  But it might
not be able to handle the key that your keyboard sends when you hold
down Control and hit `?'.

If your teminal can handle Control + `?' then you can bind it just as
you did:

(global-set-key (kbd "C-?") 'help-command)
(define-key help-map (kbd "C-?") 'help-for-help)

The fact that this does not work for you tells me that your terminal
does not recognize the key combination Control + `?'.  (That would be
the case for any ASCII terminal.)



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: Fixing key bindings on some terminals
  2014-05-26 18:32       ` Drew Adams
@ 2014-05-26 20:14         ` Kevin Le Gouguec
  2014-05-26 21:51           ` Drew Adams
  0 siblings, 1 reply; 7+ messages in thread
From: Kevin Le Gouguec @ 2014-05-26 20:14 UTC (permalink / raw)
  To: Drew Adams; +Cc: help-gnu-emacs

Woah, never realized ^? actually was the control character for DEL. Thanks!

Okay so I do not want to bind DEL to "help-command". I'd like "help-command" to be bound to "hold control then hit '?'". Right now doing this results in "delete-char", and trying to "describe-key" "C-?" gives me the description for "C-d".
I tried using 
(global-set-key (kbd "DEL") 'help-command)

But C-? still forward-deleted characters, and "describe-key" still told me I typed C-d. So I'm not sure what Terminator sends to Emacs when I hit C-? :/

Of course this is all in Terminator ; XTerm works fine. I.e. these lines...

(global-set-key (kbd "C-?") 'help-command)
(define-key help-map (kbd "C-?") 'help-for-help)

... actually do what I expect them to do.


Not sure what my options are. I don't know how hard it'd be to change Terminator to behave like XTerm when it comes to key presses. I guess it's just a matter of time before I switch to having one XTerm running Emacs with a bunch of terminals inside...


----- Original Message -----
From: "Drew Adams" <drew.adams@oracle.com>
To: "Kevin Le Gouguec" <kevin.le-gouguec@insa-lyon.fr>
Cc: help-gnu-emacs@gnu.org
Sent: Monday, May 26, 2014 8:32:41 PM
Subject: RE: Fixing key bindings on some terminals

> <snip>

Actually, the *character* `CONTROL ?' (aka ^?, an ASCII control char)
*is* `DEL' (old name `DELETE').  And it is not the key `<backspace>',
the key `<delete>', or the key `C-?'.

That is (for the last part), it might be (and probably is) the case
that when you hold Control and hit `?', you keyboard does not send a
CONTROL ? character but something else.  Yes, this is confusing.

If you do `C-h k C-i', that is, hold Control and hit `i', Emacs always
writes `TAB'.  But the same does not happen for `C-?' (holding Control
and hitting `?').  Emacs distinguishes the character ^? (aka `DEL')
from the key that is sent from your keyboard when you hold Control and
hit `?'.

So `C-h k C-?' (holding Control and hitting `?') typically tells
you that "C-? is undefined".  It does not tell you that `DELL' is
bound to...

If you want `DEL') to invoke `help-command' then bind it to
`help-command':

(global-set-key (kbd "DEL") 'help-command)
(define-key help-map (kbd "DEL") 'help-for-help) ; for `DEL DEL'

Then you can use, for example, `DEL f' for `describe-function' and
`DEL DEL' for `help-for-help'.

You might need to bind `DEL' in additional keymaps also, as some
modes bind `DEL' to other commands.  For example, in Emacs Lisp
mode `DEL' is bound to `backward-delete-char-untabify'.

> <snip>

Sorry, I know nothing about Terminator. 

An ASCII-based terminal should be able to handle `DEL'.  But it might
not be able to handle the key that your keyboard sends when you hold
down Control and hit `?'.

If your teminal can handle Control + `?' then you can bind it just as
you did:

(global-set-key (kbd "C-?") 'help-command)
(define-key help-map (kbd "C-?") 'help-for-help)

The fact that this does not work for you tells me that your terminal
does not recognize the key combination Control + `?'.  (That would be
the case for any ASCII terminal.)



^ permalink raw reply	[flat|nested] 7+ messages in thread

* RE: Fixing key bindings on some terminals
  2014-05-26 20:14         ` Kevin Le Gouguec
@ 2014-05-26 21:51           ` Drew Adams
  2014-05-26 22:39             ` Stefan Monnier
  0 siblings, 1 reply; 7+ messages in thread
From: Drew Adams @ 2014-05-26 21:51 UTC (permalink / raw)
  To: Kevin Le Gouguec; +Cc: help-gnu-emacs

> C-? ... and "describe-key" still told me I typed C-d. So I'm not sure what
> Terminator sends to Emacs when I hit C-?

Emacs thinks it is sending `C-d'.

> Not sure what my options are.

Perhaps there is a Terminator doc or mailing list you can consult?
Or maybe someone here will know something about that.



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: Fixing key bindings on some terminals
  2014-05-26 21:51           ` Drew Adams
@ 2014-05-26 22:39             ` Stefan Monnier
  0 siblings, 0 replies; 7+ messages in thread
From: Stefan Monnier @ 2014-05-26 22:39 UTC (permalink / raw)
  To: help-gnu-emacs

>> C-? ... and "describe-key" still told me I typed C-d. So I'm not sure what
>> Terminator sends to Emacs when I hit C-?
> Emacs thinks it is sending `C-d'.

No, that's just the result of normal-erase-is-backspace-mode's rewrite.


        Stefan




^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2014-05-26 22:39 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <1659521050.517588.1401091680002.JavaMail.root@insa-lyon.fr>
2014-05-26  8:32 ` Fixing key bindings on some terminals Kevin Le Gouguec
2014-05-26 15:18   ` Drew Adams
2014-05-26 15:50     ` Kevin Le Gouguec
2014-05-26 18:32       ` Drew Adams
2014-05-26 20:14         ` Kevin Le Gouguec
2014-05-26 21:51           ` Drew Adams
2014-05-26 22:39             ` Stefan Monnier

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).