Implement `modifier' run control keyword

This commit is contained in:
Thibault Jouan 2015-04-14 03:22:47 +00:00
parent 620150b6d8
commit 6ac26c370e
9 changed files with 58 additions and 18 deletions

View File

@ -0,0 +1,10 @@
Feature: `modifier' run control keyword
Scenario: configures the modifier key
Given a run control file with:
"""
modifier :ctrl
"""
And uhwm is running
When I press the ctrl+q keys
Then uhwm must terminate successfully

View File

@ -3,6 +3,8 @@ module Uh
class Env class Env
RC_PATH = '~/.uhwmrc.rb'.freeze RC_PATH = '~/.uhwmrc.rb'.freeze
MODIFIER = :mod1
LOGGER_LEVEL = Logger::WARN LOGGER_LEVEL = Logger::WARN
LOGGER_LEVEL_VERBOSE = Logger::INFO LOGGER_LEVEL_VERBOSE = Logger::INFO
LOGGER_LEVEL_DEBUG = Logger::DEBUG LOGGER_LEVEL_DEBUG = Logger::DEBUG
@ -14,11 +16,12 @@ module Uh
def_delegator :@output, :print def_delegator :@output, :print
attr_reader :output, :keybinds attr_reader :output, :keybinds
attr_accessor :verbose, :debug, :rc_path, :layout_class attr_accessor :verbose, :debug, :rc_path, :layout_class, :modifier
def initialize output def initialize output
@output = output @output = output
@rc_path = RC_PATH @rc_path = RC_PATH
@modifier = MODIFIER
@keybinds = { @keybinds = {
q: proc { quit } q: proc { quit }
} }

View File

@ -3,10 +3,11 @@ module Uh
class Manager class Manager
INPUT_MASK = Events::SUBSTRUCTURE_REDIRECT_MASK INPUT_MASK = Events::SUBSTRUCTURE_REDIRECT_MASK
attr_reader :display attr_reader :modifier, :display
def initialize events, display = Display.new def initialize events, modifier, display = Display.new
@events = events @events = events
@modifier = modifier
@display = display @display = display
end end
@ -22,7 +23,7 @@ module Uh
end end
def grab_key keysym, mod = nil def grab_key keysym, mod = nil
mod_mask = KEY_MODIFIERS[:mod1] mod_mask = KEY_MODIFIERS[@modifier]
mod_mask |= KEY_MODIFIERS[mod] if mod mod_mask |= KEY_MODIFIERS[mod] if mod
@display.grab_key keysym.to_s, mod_mask @display.grab_key keysym.to_s, mod_mask
end end

View File

@ -24,6 +24,10 @@ module Uh
instance_eval code, path instance_eval code, path
end end
def modifier mod
@env.modifier = mod
end
def key keysym, &block def key keysym, &block
@env.keybinds[translate_keysym keysym] = block @env.keybinds[translate_keysym keysym] = block
end end

View File

@ -14,12 +14,12 @@ module Uh
extend Forwardable extend Forwardable
def_delegator :@env, :layout def_delegator :@env, :layout
attr_reader :env, :events, :manager, :actions attr_reader :env, :events, :actions
def initialize env, manager: nil, stopped: false def initialize env, manager: nil, stopped: false
@env = env @env = env
@events = Dispatcher.new @events = Dispatcher.new
@manager = manager || Manager.new(@events) @manager = manager
@actions = ActionsHandler.new(@env, @events) @actions = ActionsHandler.new(@env, @events)
@stopped = stopped @stopped = stopped
end end
@ -32,6 +32,10 @@ module Uh
@stopped = true @stopped = true
end end
def manager
@manager ||= Manager.new(@events, @env.modifier)
end
def evaluate_run_control def evaluate_run_control
RunControl.evaluate(env) RunControl.evaluate(env)
end end
@ -44,14 +48,14 @@ module Uh
end end
def connect_manager def connect_manager
@manager.connect manager.connect
@env.keybinds.each do |keysym, _| @env.keybinds.each do |keysym, _|
@manager.grab_key *keysym manager.grab_key *keysym
end end
end end
def run_until &block def run_until &block
@manager.handle_pending_events until block.call manager.handle_pending_events until block.call
end end

View File

@ -21,6 +21,10 @@ module Uh
expect(env.layout_class).not_to be expect(env.layout_class).not_to be
end end
it 'has the default modifier set' do
expect(env.modifier).to eq :mod1
end
it 'has defaults key bindings set' do it 'has defaults key bindings set' do
expect(env.keybinds.keys).to eq %i[q] expect(env.keybinds.keys).to eq %i[q]
end end

View File

@ -2,8 +2,9 @@ module Uh
module WM module WM
RSpec.describe Manager do RSpec.describe Manager do
let(:events) { Dispatcher.new } let(:events) { Dispatcher.new }
let(:modifier) { :mod1 }
let(:display) { Display.new } let(:display) { Display.new }
subject(:manager) { described_class.new events, display } subject(:manager) { described_class.new events, modifier, display }
it 'has a new display' do it 'has a new display' do
expect(manager.display).to be_a Display expect(manager.display).to be_a Display
@ -47,7 +48,7 @@ module Uh
describe '#grab_key' do describe '#grab_key' do
it 'grabs given key on the display' do it 'grabs given key on the display' do
expect(manager.display) expect(manager.display)
.to receive(:grab_key).with('f', KEY_MODIFIERS[:mod1]) .to receive(:grab_key).with('f', KEY_MODIFIERS[modifier])
manager.grab_key :f manager.grab_key :f
end end
@ -55,7 +56,7 @@ module Uh
it 'grabs the key with given modifier' do it 'grabs the key with given modifier' do
expect(manager.display) expect(manager.display)
.to receive(:grab_key) .to receive(:grab_key)
.with('f', KEY_MODIFIERS[:mod1] | KEY_MODIFIERS[:shift]) .with('f', KEY_MODIFIERS[modifier] | KEY_MODIFIERS[:shift])
manager.grab_key :f, :shift manager.grab_key :f, :shift
end end
end end
@ -91,7 +92,7 @@ module Uh
describe '#handle' do describe '#handle' do
context 'when key_press event is given' do context 'when key_press event is given' do
let(:mod_mask) { KEY_MODIFIERS[:mod1] } let(:mod_mask) { KEY_MODIFIERS[modifier] }
let(:event) do let(:event) do
double 'event', double 'event',
type: :key_press, type: :key_press,
@ -105,7 +106,7 @@ module Uh
end end
context 'whith shift key modifier' do context 'whith shift key modifier' do
let(:mod_mask) { KEY_MODIFIERS[:mod1] | KEY_MODIFIERS[:shift] } let(:mod_mask) { KEY_MODIFIERS[modifier] | KEY_MODIFIERS[:shift] }
it 'emits :key event with the corresponding key and :shift' do it 'emits :key event with the corresponding key and :shift' do
events.on(:key, :f, :shift) { throw :key_press_code } events.on(:key, :f, :shift) { throw :key_press_code }

View File

@ -50,6 +50,13 @@ module Uh
end end
end end
describe '#modifier' do
it 'updates env modifier' do
rc.modifier :ctrl
expect(env.modifier).to eq :ctrl
end
end
describe '#key' do describe '#key' do
let(:code) { -> { :keybind_code } } let(:code) { -> { :keybind_code } }

View File

@ -21,10 +21,6 @@ module Uh
expect(runner.events).to be_a Dispatcher expect(runner.events).to be_a Dispatcher
end end
it 'has a manager' do
expect(runner.manager).to be_a Manager
end
it 'is not stopped' do it 'is not stopped' do
expect(runner).not_to be_stopped expect(runner).not_to be_stopped
end end
@ -53,6 +49,16 @@ module Uh
end end
end end
describe '#manager' do
it 'returns the manager' do
expect(runner.manager).to be_a Manager
end
it 'sets the manager modifier as env modifier' do
expect(runner.manager.modifier).to eq env.modifier
end
end
describe '#evaluate_run_control' do describe '#evaluate_run_control' do
it 'evaluates the run control file with RunControl and current env' do it 'evaluates the run control file with RunControl and current env' do
expect(RunControl).to receive(:evaluate).with env expect(RunControl).to receive(:evaluate).with env