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

View File

@ -116,6 +116,13 @@ module Uh
end
describe '#handle' do
let(:event) { double 'event', type: :any }
it 'emits :xevent event with the X event' do
events.on :xevent, &block
manager.handle event
end
context 'when key_press event is given' do
let(:mod_mask) { KEY_MODIFIERS[modifier] }
let(:event) do