Implement `modifier' run control keyword
This commit is contained in:
parent
620150b6d8
commit
6ac26c370e
10
features/run_control/modifier.feature
Normal file
10
features/run_control/modifier.feature
Normal 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
|
@ -3,6 +3,8 @@ module Uh
|
||||
class Env
|
||||
RC_PATH = '~/.uhwmrc.rb'.freeze
|
||||
|
||||
MODIFIER = :mod1
|
||||
|
||||
LOGGER_LEVEL = Logger::WARN
|
||||
LOGGER_LEVEL_VERBOSE = Logger::INFO
|
||||
LOGGER_LEVEL_DEBUG = Logger::DEBUG
|
||||
@ -14,11 +16,12 @@ module Uh
|
||||
def_delegator :@output, :print
|
||||
|
||||
attr_reader :output, :keybinds
|
||||
attr_accessor :verbose, :debug, :rc_path, :layout_class
|
||||
attr_accessor :verbose, :debug, :rc_path, :layout_class, :modifier
|
||||
|
||||
def initialize output
|
||||
@output = output
|
||||
@rc_path = RC_PATH
|
||||
@modifier = MODIFIER
|
||||
@keybinds = {
|
||||
q: proc { quit }
|
||||
}
|
||||
|
@ -3,10 +3,11 @@ module Uh
|
||||
class Manager
|
||||
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
|
||||
@modifier = modifier
|
||||
@display = display
|
||||
end
|
||||
|
||||
@ -22,7 +23,7 @@ module Uh
|
||||
end
|
||||
|
||||
def grab_key keysym, mod = nil
|
||||
mod_mask = KEY_MODIFIERS[:mod1]
|
||||
mod_mask = KEY_MODIFIERS[@modifier]
|
||||
mod_mask |= KEY_MODIFIERS[mod] if mod
|
||||
@display.grab_key keysym.to_s, mod_mask
|
||||
end
|
||||
|
@ -24,6 +24,10 @@ module Uh
|
||||
instance_eval code, path
|
||||
end
|
||||
|
||||
def modifier mod
|
||||
@env.modifier = mod
|
||||
end
|
||||
|
||||
def key keysym, &block
|
||||
@env.keybinds[translate_keysym keysym] = block
|
||||
end
|
||||
|
@ -14,12 +14,12 @@ module Uh
|
||||
extend Forwardable
|
||||
def_delegator :@env, :layout
|
||||
|
||||
attr_reader :env, :events, :manager, :actions
|
||||
attr_reader :env, :events, :actions
|
||||
|
||||
def initialize env, manager: nil, stopped: false
|
||||
@env = env
|
||||
@events = Dispatcher.new
|
||||
@manager = manager || Manager.new(@events)
|
||||
@manager = manager
|
||||
@actions = ActionsHandler.new(@env, @events)
|
||||
@stopped = stopped
|
||||
end
|
||||
@ -32,6 +32,10 @@ module Uh
|
||||
@stopped = true
|
||||
end
|
||||
|
||||
def manager
|
||||
@manager ||= Manager.new(@events, @env.modifier)
|
||||
end
|
||||
|
||||
def evaluate_run_control
|
||||
RunControl.evaluate(env)
|
||||
end
|
||||
@ -44,14 +48,14 @@ module Uh
|
||||
end
|
||||
|
||||
def connect_manager
|
||||
@manager.connect
|
||||
manager.connect
|
||||
@env.keybinds.each do |keysym, _|
|
||||
@manager.grab_key *keysym
|
||||
manager.grab_key *keysym
|
||||
end
|
||||
end
|
||||
|
||||
def run_until &block
|
||||
@manager.handle_pending_events until block.call
|
||||
manager.handle_pending_events until block.call
|
||||
end
|
||||
|
||||
|
||||
|
@ -21,6 +21,10 @@ module Uh
|
||||
expect(env.layout_class).not_to be
|
||||
end
|
||||
|
||||
it 'has the default modifier set' do
|
||||
expect(env.modifier).to eq :mod1
|
||||
end
|
||||
|
||||
it 'has defaults key bindings set' do
|
||||
expect(env.keybinds.keys).to eq %i[q]
|
||||
end
|
||||
|
@ -2,8 +2,9 @@ module Uh
|
||||
module WM
|
||||
RSpec.describe Manager do
|
||||
let(:events) { Dispatcher.new }
|
||||
let(:modifier) { :mod1 }
|
||||
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
|
||||
expect(manager.display).to be_a Display
|
||||
@ -47,7 +48,7 @@ module Uh
|
||||
describe '#grab_key' do
|
||||
it 'grabs given key on the display' do
|
||||
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
|
||||
end
|
||||
|
||||
@ -55,7 +56,7 @@ module Uh
|
||||
it 'grabs the key with given modifier' do
|
||||
expect(manager.display)
|
||||
.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
|
||||
end
|
||||
end
|
||||
@ -91,7 +92,7 @@ module Uh
|
||||
|
||||
describe '#handle' do
|
||||
context 'when key_press event is given' do
|
||||
let(:mod_mask) { KEY_MODIFIERS[:mod1] }
|
||||
let(:mod_mask) { KEY_MODIFIERS[modifier] }
|
||||
let(:event) do
|
||||
double 'event',
|
||||
type: :key_press,
|
||||
@ -105,7 +106,7 @@ module Uh
|
||||
end
|
||||
|
||||
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
|
||||
events.on(:key, :f, :shift) { throw :key_press_code }
|
||||
|
@ -50,6 +50,13 @@ module Uh
|
||||
end
|
||||
end
|
||||
|
||||
describe '#modifier' do
|
||||
it 'updates env modifier' do
|
||||
rc.modifier :ctrl
|
||||
expect(env.modifier).to eq :ctrl
|
||||
end
|
||||
end
|
||||
|
||||
describe '#key' do
|
||||
let(:code) { -> { :keybind_code } }
|
||||
|
||||
|
@ -21,10 +21,6 @@ module Uh
|
||||
expect(runner.events).to be_a Dispatcher
|
||||
end
|
||||
|
||||
it 'has a manager' do
|
||||
expect(runner.manager).to be_a Manager
|
||||
end
|
||||
|
||||
it 'is not stopped' do
|
||||
expect(runner).not_to be_stopped
|
||||
end
|
||||
@ -53,6 +49,16 @@ module Uh
|
||||
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
|
||||
it 'evaluates the run control file with RunControl and current env' do
|
||||
expect(RunControl).to receive(:evaluate).with env
|
||||
|
Loading…
x
Reference in New Issue
Block a user