-
Notifications
You must be signed in to change notification settings - Fork 252
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
macos: error when starting both mouse and keyboard listeners #55
Comments
Hi there, Any news ? Thanks ! |
Hi, Sorry for the late reply. Could you provide a minimal test that causes the error? I started investigating this, but kivy installation using |
Hi there, Yep, the kivy docs are a bit messy sometime but as they state here, you have to install Cython first. On my macbook, i use kivy 0.10.0 with Cython 0.26.1. Thanks again for investigating ! |
Here is a minimal example : from pynput import mouse
def on_move(x, y):
print('Pointer moved to {0}'.format(
(x, y)))
def on_click(x, y, button, pressed):
print('{0} at {1}'.format(
'Pressed' if pressed else 'Released',
(x, y)))
if not pressed:
# Stop listener
return False
def on_scroll(x, y, dx, dy):
print('Scrolled {0} at {1}'.format(
'down' if dy < 0 else 'up',
(x, y)))
from pynput import keyboard
def on_press(key):
try:
print('alphanumeric key {0} pressed'.format(
key.char))
except AttributeError:
print('special key {0} pressed'.format(
key))
def on_release(key):
print('{0} released'.format(
key))
if key == keyboard.Key.esc:
# Stop listener
return False
import kivy
kivy.require('1.10.0')
from kivy.app import App
from kivy.uix.label import Label
class MyApp(App):
def build(self):
# Collect events until released
with mouse.Listener(
on_move=on_move,
on_click=on_click,
on_scroll=on_scroll) as listener:
listener.join()
# Collect events until released
with keyboard.Listener(
on_press=on_press,
on_release=on_release) as listener:
listener.join()
return Label(text='Hello world')
if __name__ == '__main__':
MyApp().run() |
Again, sorry for the late reply. My mac development station is a Mac Mini from 2009 running El Capitan, so it's not exactly a pleasure to use ;-) When I run
pygame does not install, complaining about missing SDL headers. |
Hi, I am having the same issue (I don't use kivy though..)
|
@Djiit did you fix it? Maybe some fork? Workaround? |
@gabycperezdias It appears that you run pynput outside of a virtualenv, and that the version of pyobjc-core shipped with High Sierra is 4.2. pynput has been tested with pyobjc-core 3. Have you tried running it inside of a virtualenv with the dependency versions specified in |
Hi, I can't really use a virtualenv because of the integration with wxpython (there's a issue that this library won't work inside a virtualenv). But, I've downgraded my pyojbc to 3.2.1 (which is whithin your range right?) I still have a mix of 'random' errors, I've got a print from the same error as Djiit: Traceback (most recent call last): File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/threading.py", line 916, in _bootstrap_inner self.run() File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/pynput-1.3.7-py3.6.egg/pynput/_util/__init__.py", line 122, in run self._run() File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/pynput-1.3.7-py3.6.egg/pynput/keyboard/_darwin.py", line 183, in _run super(Listener, self)._run() File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/pynput-1.3.7-py3.6.egg/pynput/_util/darwin.py", line 186, in _run loop_source = Quartz.CFMachPortCreateRunLoopSource( File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/objc/_lazyimport.py", line 163, in __getattr__ raise AttributeError(name) AttributeError: CFMachPortCreateRunLoopSource |
Any update regarding this issue? I am trying to listen the mouse and the keyboard but I am getting the same error. The error is only on Mac os, windows working fine. |
Could you provide a sample script exhibiting the error, and an accompanying stack trace? As noted on Stack Overflow, this might be related to threading. |
Ok, I found the solution. It is a threading problem. Putting the keyboard listener in separate thread fixed the problem.
|
Thank you for your prompt response. Can you please provide your original, non-working script as well? I am curious to see what might cause this issue. |
No problem, non-working code:
|
Thank you. I guess that the lazy-loading used by |
Is this a known issue? Any timeline for a solution? |
I quick search suggests that it was a known issue in |
Any updates now? I am also experiencing the same problem on Python 3.8.5 and macOS 11.0 beta. |
So I've run into a similar problem on my mac, though I have been able to get a mouse and keyboard listener to work at the same time (I confirmed this over many tests. I never saw problems with both listeners running at the same time). What I'm encountering though is that when I try to add a keyboard controller to the mix, it breaks things. What I see:
Here's a minimum example to repro the error:
I'm on:
Kinda unfortunate. I've been using pynput for months on ubuntu 18.04 and loved it, never had any problems. Trying to run the same codebase on mac, I ran into this 😞 Anybody have any suggestions for fixes yet? |
I have had success running mouse and keyboard listeners at the same time on macOS using |
@fohara gotcha, thanks. Good to know, I was thinking I'd have to split my code into different scripts and use a socket or something. Multiprocessing sounds a lot more straightforward. |
PyObjC developer here, this is a bug in PyObjC that I intend to fix. The lazy loader contains a race condition when resolving an attribute from multiple threads. |
As a workaround, all changes in pynput/_util/darwin.py:
This way the symbols are resolved eagerly at import time and that avoids the race condition. That race condition will be fixed in PyObjC 8, which will be released sometime around the release of macOS Monterey later this year. |
Thank you @ronaldoussoren for yout input! Would you advise to also change the keyboard and mouse implementations? |
I haven't look at the implementation for those, but in general doing "from ... import ..." for the symbols from CoreFoundation and Quartz that you use should avoid the race condition you're running in because import statements are serialized by a lock in the import system. I have a fix for the race condition in PyObjC that will land in PyObjC 8, but that doesn't help you right now. |
Hi there, are we sure this was fixed in pyobjc 8.0? i am experiencing this issue with pyobjc 8.4.1 and pynput 1.7.6 I see you reverted the pynput fix in Nov '21 (0c0c9b3) |
Hi there, Setting a delay between the starting of the two listeners fixed the problem. Here is an example for recreating the problem that occurred: def on_press(key): def on_release(key): def on_click(x, y, button, pressed): keyboard listenerkeyb = keyboard.Listener( mouse listenermous = mouse.Listener(on_click=on_click) start both listenerskeyb.start() while True: The Error is something like this: (one of the two listens will not work) With a delay tho, both listeners worked fine at my setup: def on_press(key): def on_release(key): def on_click(x, y, button, pressed): keyboard listenerkeyb = keyboard.Listener( mouse listenermous = mouse.Listener(on_click=on_click) start keyboard listenerkeyb.start() add delaytime.sleep(1) start mouse listenermous.start() while True: The important part here is the "time.sleep(1)". Maybe this solution can help someone who runs himself into this problem. |
You can also use |
@ronaldoussoren Your fix worked for me 🎉 But I have pyobjc-core==10.1, which should per your comment already be fixed? |
@lettow-humain Thanks man! worked like a charm <3 |
Hi there,
Tested on last MacOS version, python 3.6.2, with root privileges to ensure keyboard is correctly monitored.
Using both keyboard and mouse listener in a Kivy application throw me this error :
Tested without Kivy context (adapting examples from the doc to use the
.start()
method instead of the context manager ), it works perfectly. Any idea of what could be causing this ?Please tell me if I can help :)
The text was updated successfully, but these errors were encountered: