Log X events received by the manager

This commit is contained in:
Thibault Jouan
2015-04-16 13:19:29 +00:00
parent 6ad1735775
commit d781a48837
3 changed files with 32 additions and 0 deletions

View File

@@ -42,6 +42,7 @@ module Uh
end
def handle event
@events.emit :xevent, args: event
return unless respond_to? handler = "handle_#{event.type}".to_sym, true
send handler, event
end

View File

@@ -78,6 +78,7 @@ module Uh
@env.log "Connected to X server on `#{display}'"
end
@events.on(:disconnected) { @env.log "Disconnected from X server" }
@events.on(:xevent) { |event| XEventLogger.new(env).log_event event }
end
def register_layout_hooks
@@ -94,6 +95,29 @@ module Uh
@events.on(:key, *keysym) { @actions.evaluate code }
end
end
class XEventLogger
def initialize env
@env = env
end
def log_event xev
complement = case xev.type
when :key_press
"window: #{xev.window} key: #{xev.key} mask: #{xev.modifier_mask}"
when :map_request
"window: #{xev.window}"
end
@env.log_debug [
'XEvent',
xev.type,
xev.send_event ? 'SENT' : nil,
complement
].compact.join ' '
end
end
end
end
end