Log X events received by the manager
This commit is contained in:
parent
6ad1735775
commit
d781a48837
@ -42,6 +42,7 @@ module Uh
|
|||||||
end
|
end
|
||||||
|
|
||||||
def handle event
|
def handle event
|
||||||
|
@events.emit :xevent, args: event
|
||||||
return unless respond_to? handler = "handle_#{event.type}".to_sym, true
|
return unless respond_to? handler = "handle_#{event.type}".to_sym, true
|
||||||
send handler, event
|
send handler, event
|
||||||
end
|
end
|
||||||
|
@ -78,6 +78,7 @@ module Uh
|
|||||||
@env.log "Connected to X server on `#{display}'"
|
@env.log "Connected to X server on `#{display}'"
|
||||||
end
|
end
|
||||||
@events.on(:disconnected) { @env.log "Disconnected from X server" }
|
@events.on(:disconnected) { @env.log "Disconnected from X server" }
|
||||||
|
@events.on(:xevent) { |event| XEventLogger.new(env).log_event event }
|
||||||
end
|
end
|
||||||
|
|
||||||
def register_layout_hooks
|
def register_layout_hooks
|
||||||
@ -94,6 +95,29 @@ module Uh
|
|||||||
@events.on(:key, *keysym) { @actions.evaluate code }
|
@events.on(:key, *keysym) { @actions.evaluate code }
|
||||||
end
|
end
|
||||||
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
|
end
|
||||||
end
|
end
|
||||||
|
@ -116,6 +116,13 @@ module Uh
|
|||||||
end
|
end
|
||||||
|
|
||||||
describe '#handle' do
|
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
|
context 'when key_press event is given' do
|
||||||
let(:mod_mask) { KEY_MODIFIERS[modifier] }
|
let(:mod_mask) { KEY_MODIFIERS[modifier] }
|
||||||
let(:event) do
|
let(:event) do
|
||||||
|
Loading…
x
Reference in New Issue
Block a user