Opened 16 years ago
Closed 13 years ago
#2241 closed bug (fixed)
~ (tilde) Key requires a double keypress to be displayed
Reported by: | scottmc | Owned by: | jscipione |
---|---|---|---|
Priority: | normal | Milestone: | R1 |
Component: | Servers/input_server | Version: | R1/pre-alpha1 |
Keywords: | Cc: | ||
Blocked By: | Blocking: | ||
Platform: | All |
Description
At first I just thought I have a bad key on my keyboard, but now I've noticed it happens only when I'm in Haiku and happens on any keyboard I've used in Haiku so it seems it's a haiku bug. Not sure if this is related to an already reported bug or not though.
Change History (19)
follow-up: 2 comment:1 by , 16 years ago
comment:2 by , 16 years ago
Replying to axeld:
Isn't that just the default for the US-International keymap? IOW it's just a deadkey and should be like that?
Maybe, but then we should change the default keymap to American, which seems to work as expected.
comment:3 by , 16 years ago
Yes, it's always been this way in the default image AFAICR.
Interestingly, if you execute "cd ~" and the ~ doesn't appear in the shell (because you didn't press it twice) it still changes to your home directory anyway :)
comment:4 by , 16 years ago
Cc: | added |
---|
Isn't that just the default for the US-International keymap? IOW it's just a deadkey and should be like that?
Yes, this is in fact the expected behavior for the US-International keymap.
comment:5 by , 16 years ago
But there is definitely something fishy with the ~ key. It works differently in Haiku than what I am used to. For example, if you press it and then move the cursor, it should dump the character. I think in Haiku you have to press it twice for that to happen.
comment:6 by , 16 years ago
The behavior described in this bug is the expected behavior of a deadkey; for example, pressing "~" followed by "n" will display "ñ".
There is some strange behavior when you want to cancel input before you press the second keystroke, but it looks to me like that would probably require a different bug report.
comment:7 by , 16 years ago
I've got this annoying problem here too since forever (fr keymap, not sure its relevant, see below)
Interestingly i just noticed that the bug appears only when you type rapidly '~' then 'space'. Waiting a bit after typing '~' shows the expected behavior. In terminal, it seems there is a change in the cursor blinking when its ok to type the second key. Tested in Terminal and StyledEdit.
HTH
comment:8 by , 16 years ago
Yes, the bahaviour is very weird. You actually have to delay typing the following key after a dead key for it to work as expected and this kills my typing speed. A timing issue in input_server maybe?
comment:9 by , 16 years ago
Summary: | ~ (tilda) Key requires a double keypress to be displayed → ~ (tilde) Key requires a double keypress to be displayed |
---|
comment:10 by , 15 years ago
This has changed recently (i'm guessing in builds after hrev30700 or so?), now you only need to press the ~ key once to have it register, but it doesn't get displayed until another key is pressed. Pressing it twice will give you .
comment:11 by , 15 years ago
Tilde is a dead key in the US-International layout, so this should be the expected behavior. Unless I miss something, the ticket can be closed.
comment:12 by , 15 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
comment:13 by , 13 years ago
Component: | - General → Servers/input_server |
---|---|
Resolution: | fixed |
Status: | closed → reopened |
I am reopening this bug as I am working on adding AltGr (Shift Level 3) maps to the keymaps which will fix this bug more properly by assigning the deadkey to option+n instead of ~. To type ñ you type either left-option+N followed by N or right-option+N. This will free up the ~ key for use in the terminal and other places. Setting deadkeys in the normal map of the default keymap is not acceptable for American users. International users use a different keymap, or, use the special keys provided via the Shift Level 2 and 3 maps in US-International.
comment:14 by , 13 years ago
Owner: | changed from | to
---|---|
Status: | reopened → assigned |
Assigning this ticket to myself
follow-up: 16 comment:15 by , 13 years ago
You're talking about the American keymap, right? If not, I don't get it.
comment:16 by , 13 years ago
Replying to korli:
You're talking about the American keymap, right? If not, I don't get it.
I am talking about US-International. Elucidate on what you don't get.
The American keymap (which I believe should be renamed "US" or "US-ASCII" since "American" is ambiguous) has no special characters in the option tables nor the altGr tables nor any dead keys. It produces only ASCII/single-bit UTF-8 characters.
follow-up: 18 comment:17 by , 13 years ago
I think US-International is meant for international users, not american users as you seem to imply.
comment:18 by , 13 years ago
Replying to korli:
I think US-International is meant for international users, not american users as you seem to imply.
Yes, that is mostly correct, although it is also used by English-speaking Canadian users.
But the US-International keymap is also used by American users with International needs. It is useful for any English-speaking country other than the UK and Ireland, (which use their own slightly different keymap) as well the Netherlands, (a Dutch speaking country that uses US-International).
If you fit the above description and regularly need to type multibyte UTF-8 characters, US-International is for you.
Now, getting back to the bug described by this ticket... the American and US-International keymaps should have identical normal, control, and shift maps. They are different only in regards to the option map. But, the dead keys specified in the normal maps breaks this causing this bug. Yes, you could use the American keymap to disable the deadkeys, but, then you also lose the international characters produced by the option key as well.
It is my intention to alter the US-International keymap so that it will produce dead keys only in combination with the option key, and to also to add additional support for special characters needed by international users making US-International suitable for all users specified above and most American and English speaking Canadian users as well.
comment:19 by , 13 years ago
Resolution: | → fixed |
---|---|
Status: | assigned → closed |
As of hrev43956 the dead keys have been moved to the option map for US-International. Therefore ~ is accessible via a single key press.
Isn't that just the default for the US-International keymap? IOW it's just a deadkey and should be like that?