from zkfcfbzr@lemmy.world to programming@programming.dev on 31 Mar 05:01
https://lemmy.world/post/27601594
cross-posted from: lemmy.world/post/27385536
I have a rather large Python script that I use as basically a replacement for autohotkey. It uses pynput for keyboard and mouse control - and at least on Windows, it works exactly how I expect.
I recently started dual-booting with Linux and have been trying to get the script to work here as well. It does work but with mixed results - in particular, I found that pynput has bizarrely wrong output for special characters, in a way thatβs both consistent and inconsistent.
The simplest possible case I found that reproduces the error is this script:
import time from pynput import keyboard # Sleep statement is just to give time to move the mouse cursor to a text input field time.sleep(2) my_kb = keyboard.Controller() text = 'π' # Eggplant emoji my_kb.type(text) time.sleep(1) text = 'π₯ππ€π₯' # blackboard bold test my_kb.type(text) time.sleep(1) text = 'πππ¬π' # bold test my_kb.type(text)When I run that script right now, it produces the output βππ₯π₯π€π₯πππ¬πβ. And if I run it again, itβll produce the same output. And if I change the eggplant emoji to something else, like the regular character βAβ, it will still produce the same output (specifically βAπ₯π₯π€π₯πππ¬πβ). Butβ¦ If I log out and log back in, then the output changes to something else thatβs still wrong, but differently. For example, when I changed the eggplant to a regular βAβ, then relogged, the output became βAπ₯πππ₯ππππβ. And then that wrong output will keep being the same wrong output until I log out and back in again. If the test strings donβt change, then the incorrect outputs donβt change on relog - but if they do, then they do.
In the larger script, errors seemed to chain together somehow - like if I produced an eggplant emoji, then tried to write blackboard bold test, I would get βπππ€πβ. This is despite verifying just before running the pynput.keyboard.Controller.type function that what it was about to type was correct. The issue also happens if I type it character-by-character with press and release functions.
I am very new to Linux. Iβm on Linux Mint. Iβm running this in a python3 venv that just has pynput and two other external libraries installed. ChatGPT thinks the issue might be related to X11. The issue does not occur at all on Windows, using the exact same code. On Linux there seems to be no issues with typing regular text, just special characters.
#programming
threaded - newest
I tried to replicate this in KDE (wayland).
pynput has no effect on wayland, which I figured. I then enabled ibus wayland to type unicode points with ctrl+shift+u, but everything came out as expected. So I think it is related to the xorg backend of pynput.