Configure upcased key as combination with shift mod

This commit is contained in:
Thibault Jouan
2015-04-15 01:09:18 +00:00
parent 56197c85f8
commit 9c9aa1dabb
7 changed files with 63 additions and 9 deletions

View File

@@ -49,8 +49,17 @@ module Uh
describe '#grab_key' do
it 'grabs given key on the display' do
expect(manager.display)
.to receive(:grab_key).with('q', KEY_MODIFIERS[:mod1])
manager.grab_key :q
.to receive(:grab_key).with('f', KEY_MODIFIERS[:mod1])
manager.grab_key :f
end
context 'when a modifier is given' do
it 'grabs the key with given modifier' do
expect(manager.display)
.to receive(:grab_key)
.with('f', KEY_MODIFIERS[:mod1] | KEY_MODIFIERS[:shift])
manager.grab_key :f, :shift
end
end
end
@@ -84,12 +93,27 @@ module Uh
describe '#handle' do
context 'when key_press event is given' do
let(:event) { double 'event', type: :key_press, key: 'q' }
let(:mod_mask) { KEY_MODIFIERS[:mod1] }
let(:event) do
double 'event',
type: :key_press,
key: 'f',
modifier_mask: mod_mask
end
it 'emits :key event with the corresponding key' do
events.on(:key, :q) { throw :key_press_code }
events.on(:key, :f) { throw :key_press_code }
expect { manager.handle event }.to throw_symbol :key_press_code
end
context 'whith shift key modifier' do
let(:mod_mask) { KEY_MODIFIERS[:mod1] | KEY_MODIFIERS[:shift] }
it 'emits :key event with the corresponding key and :shift' do
events.on(:key, :f, :shift) { throw :key_press_code }
expect { manager.handle event }.to throw_symbol :key_press_code
end
end
end
end
end

View File

@@ -66,6 +66,11 @@ module Uh
rc.key :enter, &code
expect(env.keybinds.keys).to include :Return
end
it 'translates upcased key name to a combination with shift' do
rc.key :F, &code
expect(env.keybinds.keys).to include %i[f shift]
end
end
end
end

View File

@@ -80,6 +80,12 @@ module Uh
runner.register_event_hooks
expect(runner.events[:key, :f]).not_to be_empty
end
it 'registers combined key bindings event hooks' do
env.keybinds[[:f, :shift]] = -> { }
runner.register_event_hooks
expect(runner.events[:key, :f, :shift]).not_to be_empty
end
end
describe '#connect_manager' do