Skip to content

Commit

Permalink
gh-106751: Optimize kqueue selector of the event loop
Browse files Browse the repository at this point in the history
  • Loading branch information
corona10 committed Jul 18, 2023
1 parent aecf6ac commit 48d2aaa
Showing 1 changed file with 6 additions and 8 deletions.
14 changes: 6 additions & 8 deletions Lib/selectors.py
Original file line number Diff line number Diff line change
Expand Up @@ -547,23 +547,21 @@ def select(self, timeout=None):
# If max_ev is 0, kqueue will ignore the timeout. For consistent
# behavior with the other selector classes, we prevent that here
# (using max). See https://bugs.python.org/issue29255
max_ev = max(len(self._fd_to_key), 1)
max_ev = len(self._fd_to_key) or 1
ready = []
try:
kev_list = self._selector.control(None, max_ev, timeout)
except InterruptedError:
return ready

fd_to_key = self._fd_to_key
for kev in kev_list:
fd = kev.ident
flag = kev.filter
events = 0
if flag == select.KQ_FILTER_READ:
events |= EVENT_READ
if flag == select.KQ_FILTER_WRITE:
events |= EVENT_WRITE

key = self._fd_to_key.get(fd)
key = fd_to_key.get(fd)
if key:
events = ((flag == select.KQ_FILTER_READ and EVENT_READ)
| (flag == select.KQ_FILTER_WRITE and EVENT_WRITE))
ready.append((key, events & key.events))
return ready

Expand Down

0 comments on commit 48d2aaa

Please sign in to comment.