Page 1 of 1
[Donion] [1.1.82] CTRL key stopped working on Linux
Posted: Tue May 23, 2023 9:19 am
by Pi-C
I've backed up my Factorio folder for version 1.1.81 and updated to 1.1.82. When I tried to use CTRL+F to find a saved game, it didn't work, and going to Settings--> Controls, I noticed that the CTRL key is ignored altogether.
I've restarted my system (Debian/Sid, with MATE desktop) after yesterday's updates, so there was a slight chance that something might have been borked with the updates. However, switching to the backup folder and starting Factorio 1.1.81, the CTRL key worked as expected again. So it seems that updating Factorio to 1.1.82 disabled the CTRL key. (Actually, the CTRL key works as expected with all other programs, only Factorio ignores it.)
Re: 1.1.82: CTRL key stopped working on Linux
Posted: Tue May 23, 2023 9:54 am
by Donion
Do you have your Ctrl mapped to/swapped with some other key? Or any other custom keyboard settings? Are you using Wayland?
Re: 1.1.82: CTRL key stopped working on Linux
Posted: Tue May 23, 2023 9:54 am
by jodokus31
Probably related to this:
106031
Re: 1.1.82: CTRL key stopped working on Linux
Posted: Tue May 23, 2023 12:06 pm
by Pi-C
Donion wrote: Tue May 23, 2023 9:54 am
Do you have your Ctrl mapped to/swapped with some other key? Or any other custom keyboard settings? Are you using Wayland?
No, I'm not using Wayland. After some experimenting I've found that my mouse preferences interfered with the CTRL key:

- mouse_prefs.png (64.88 KiB) Viewed 2546 times
Turning off this setting will enable CTRL in Factorio 1.1.82, turning it on again disables CTRL. I'm not sure why this happens all of a sudden, I've used this setting for years and it didn't affect Factorio until now. (Actually,
I've had this issue before, but it had been fixed in 0.17.44.)
Re: 1.1.82: CTRL key stopped working on Linux
Posted: Tue May 23, 2023 12:44 pm
by Donion
I was afraid of that.
The reason why all this is happening is that recently I've updated SDL to a newer version and the fix for your issue was breaking a bunch of other cases.
I've tested a similar "show cursor position" functionality on my setup and it works without a problem in 1.1.82, but clearly your specific one does things differently.
I will try to reproduce it on my end and figure out a new fix. In the meantime you should disable the feature (or try using a different tool, if you do try and it's broken as well, please, let me know) or use the previous version. I'm sorry for the inconvenience.
Update: I can reproduce it on Mint with Cinnamon
Re: 1.1.82: CTRL key stopped working on Linux
Posted: Thu May 25, 2023 7:52 am
by Pi-C
Donion wrote: Tue May 23, 2023 12:44 pm
I will try to reproduce it on my end and figure out a new fix. In the meantime you should disable the feature (or try using a different tool, if you do try and it's broken as well, please, let me know) or use the previous version. I'm sorry for the inconvenience.
I've disabled the feature for now. Highlighting the cursor position is a nice-to-have feature but not essential, and now that I know how to get back the CTRL key, I can live with that for a while.
Update: I can reproduce it on Mint with Cinnamon
Great! So there is a chance that you'll find a fix as well. Thanks a lot for your efforts!

Re: [Donion] [1.1.82] CTRL key stopped working on Linux
Posted: Mon Feb 12, 2024 12:49 pm
by Donion
I've looked into this further now, with SDL 2.30.0 and this is what's happening when I have the "show cursor when Ctrl is pressed" enabled on Mint with Cinnamon:
- I press Ctrl key
- Factorio receives FocusOut event
- I release Ctrl key
- Factorio receives FocusOut event (I don't know why there is this second FocusOut event)
- Factorio receives FocusIn event
- Factorio receives KeymapNotify event, the X11 driver reconciles the keyboard state.
This looks reasonable, however, by the time Factorio receives the KeymapNotify event the Ctrl is already released so the keyboard reconciliation doesn't really do anything and the Ctrl key press and release is lost to us.
In the past Oxyd put in several workarounds to reconcile the keyboard state also on every key press and mouse click, I have since removed those as they were causing other issues. Also this approach wouldn't work for actions bound to just "Ctrl" (for example, if you have Alt-mode key set as Ctrl).
I'm leaning towards leaving this as a minor issue.
I might revisit this later, ideally by having a fix in upstream SDL.