Skip to content

Commit

Permalink
fix: added exception handling for Xlib.error.BadWindow (#97)
Browse files Browse the repository at this point in the history
Implemented a try/except block to catch the `Xlib.error.BadWindow` error during window name and class fetching.
This change prevents the appearance of unnecessary messages in the logs,
which although they do not affect the performance or operation of the watcher,
they generate noise and do not provide relevant information about the error.
With this enhancement, in case this error is detected, the window name or class will be set to "unknown",
allowing the process to continue without interruption
  • Loading branch information
0xErwin1 authored May 13, 2024
1 parent 76c85c6 commit 7a89db4
Showing 1 changed file with 26 additions and 9 deletions.
35 changes: 26 additions & 9 deletions aw_watcher_window/xlib.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,15 +73,24 @@ def get_window_name(window: Window) -> str:
# But I don't know, so I pass the thing on, for now.
d = None
if d is None or d.format != 8:
# Fallback.
r = window.get_wm_name()
if isinstance(r, str):
return r
else:
logger.warning(
"I don't think this case will ever happen, but not sure so leaving this message here just in case."
)
return r.decode("latin1") # WM_NAME with type=STRING.
try:
# Fallback.
r = window.get_wm_name()
if isinstance(r, str):
return r
else:
logger.warning(
"I don't think this case will ever happen, but not sure so leaving this message here just in case."
)
return r.decode("latin1") # WM_NAME with type=STRING.
except Xlib.error.BadWindow as e:
# I comment on the log, the number of messages that pop up is very annoying
# Also, it does not give much information about the error
# But I leave it in case someone sees it useful
# logger.warning(
# f"Unable to get window property WM_NAME, got a {type(e).__name__} exception from Xlib"
# )
return "unknown"
else:
# Fixing utf8 issue on Ubuntu (https://github.com/gurgeh/selfspy/issues/133)
# Thanks to https://github.com/gurgeh/selfspy/issues/133#issuecomment-142943681
Expand Down Expand Up @@ -112,6 +121,14 @@ def get_window_class(window: Window) -> str:
logger.warning("Code made an unclear branch")
try:
window = window.query_tree().parent
except Xlib.error.BadWindow:
# I comment on the log, the number of messages that pop up is very annoying
# Also, it does not give much information about the error
# But I leave it in case someone sees it useful
# logger.warning(
# "Unable to get window query_tree().parent, got a BadWindow exception."
# )
return "unknown"
except Xlib.error.XError as e:
logger.warning(
f"Unable to get window query_tree().parent, got a {type(e).__name__} exception from Xlib"
Expand Down

0 comments on commit 7a89db4

Please # to comment.