mirror of
https://github.com/Llewellynvdm/fzf.git
synced 2025-01-11 02:36:12 +00:00
Minor refactoring
This commit is contained in:
parent
aad335475c
commit
b0eca20dc2
52
fzf
52
fzf
@ -174,7 +174,8 @@ class FZF
|
|||||||
|
|
||||||
Environment variables
|
Environment variables
|
||||||
FZF_DEFAULT_COMMAND Default command to use when input is tty
|
FZF_DEFAULT_COMMAND Default command to use when input is tty
|
||||||
FZF_DEFAULT_OPTS Defaults options. (e.g. "-x -m --sort 10000")] + $/ + $/
|
FZF_DEFAULT_OPTS Defaults options. (e.g. "-x -m --sort 10000")
|
||||||
|
FZF_MOUSE_ENABLED Set to 0 to disable mouse] + $/ + $/
|
||||||
exit x
|
exit x
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -471,7 +472,7 @@ class FZF
|
|||||||
|
|
||||||
def init_screen
|
def init_screen
|
||||||
C.init_screen
|
C.init_screen
|
||||||
if ENV.fetch('FZF_MOUSE_ENABLED', '1') == '1'
|
unless ENV.fetch('FZF_MOUSE_ENABLED', '1') == '0'
|
||||||
C.mouseinterval 0
|
C.mouseinterval 0
|
||||||
C.mousemask C::ALL_MOUSE_EVENTS
|
C.mousemask C::ALL_MOUSE_EVENTS
|
||||||
end
|
end
|
||||||
@ -715,6 +716,10 @@ class FZF
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_mouse st, *states
|
||||||
|
states.any? { |s| s & st > 0 }
|
||||||
|
end
|
||||||
|
|
||||||
def start_loop
|
def start_loop
|
||||||
got = nil
|
got = nil
|
||||||
begin
|
begin
|
||||||
@ -765,13 +770,13 @@ class FZF
|
|||||||
nil
|
nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
actions[C::KEY_UP] = actions[ctrl(:p)] = actions[ctrl(:k)]
|
||||||
|
actions[C::KEY_DOWN] = actions[ctrl(:n)] = actions[ctrl(:j)]
|
||||||
actions[C::KEY_LEFT] = actions[ctrl(:b)]
|
actions[C::KEY_LEFT] = actions[ctrl(:b)]
|
||||||
actions[C::KEY_RIGHT] = actions[ctrl(:f)]
|
actions[C::KEY_RIGHT] = actions[ctrl(:f)]
|
||||||
actions[127] = actions[ctrl(:h)]
|
actions[C::KEY_BTAB] = actions[:select] = actions[ctrl(:i)]
|
||||||
actions[C::KEY_DOWN] = actions[ctrl(:n)] = actions[ctrl(:j)]
|
actions[C::KEY_BACKSPACE] = actions[127] = actions[ctrl(:h)]
|
||||||
actions[C::KEY_UP] = actions[ctrl(:p)] = actions[ctrl(:k)]
|
|
||||||
actions[ctrl(:q)] = actions[ctrl(:g)] = actions[ctrl(:c)] = actions[:esc]
|
actions[ctrl(:q)] = actions[ctrl(:g)] = actions[ctrl(:c)] = actions[:esc]
|
||||||
actions[:select] = actions[C::KEY_BTAB] = actions[ctrl(:i)]
|
|
||||||
|
|
||||||
emit(:key) { [@query.get, cursor] } unless @query.empty?
|
emit(:key) { [@query.get, cursor] } unless @query.empty?
|
||||||
pmv = nil
|
pmv = nil
|
||||||
@ -786,15 +791,15 @@ class FZF
|
|||||||
when C::KEY_MOUSE
|
when C::KEY_MOUSE
|
||||||
if m = C.getmouse
|
if m = C.getmouse
|
||||||
st = m.bstate
|
st = m.bstate
|
||||||
if ((st & C::BUTTON1_PRESSED) | (st & C::BUTTON1_RELEASED)) > 0
|
if test_mouse(st, C::BUTTON1_PRESSED, C::BUTTON1_RELEASED)
|
||||||
if m.y == cursor_y
|
if m.y == cursor_y
|
||||||
# TODO Wide-characters
|
# TODO Wide-characters
|
||||||
cursor = [0, [input.length, m.x - 2].min].max
|
cursor = [0, [input.length, m.x - 2].min].max
|
||||||
elsif m.x > 1 && m.y <= max_items
|
elsif m.x > 1 && m.y <= max_items
|
||||||
vselect { |v|
|
vselect { |v|
|
||||||
tv = max_items - m.y - 1
|
tv = max_items - m.y - 1
|
||||||
if st & C::BUTTON1_RELEASED > 0
|
if test_mouse(st, C::BUTTON1_RELEASED)
|
||||||
if (st & C::BUTTON_SHIFT) > 0
|
if test_mouse(st, C::BUTTON_SHIFT)
|
||||||
ch = :select
|
ch = :select
|
||||||
elsif pmv == tv
|
elsif pmv == tv
|
||||||
ch = ctrl(:m)
|
ch = ctrl(:m)
|
||||||
@ -804,9 +809,9 @@ class FZF
|
|||||||
tv
|
tv
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
elsif ((st & 0x8000000) | (st & C::BUTTON2_PRESSED)) > 0
|
elsif test_mouse(st, 0x8000000, C::BUTTON2_PRESSED)
|
||||||
ch = C::KEY_DOWN
|
ch = C::KEY_DOWN
|
||||||
elsif (st & C::BUTTON4_PRESSED) > 0
|
elsif test_mouse(st, C::BUTTON4_PRESSED)
|
||||||
ch = C::KEY_UP
|
ch = C::KEY_UP
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -820,26 +825,25 @@ class FZF
|
|||||||
else
|
else
|
||||||
ch2
|
ch2
|
||||||
end
|
end
|
||||||
when Fixnum
|
|
||||||
# Ruby 1.8
|
|
||||||
if (ch.chr rescue nil) && ch.chr =~ /[[:print:]]/
|
|
||||||
ch = ch.chr
|
|
||||||
else
|
|
||||||
chs = [ch]
|
|
||||||
(num_unicode_bytes(ch) - 1).times do |i|
|
|
||||||
chs << C.getch
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
upd = actions.fetch(ch, proc { |ch|
|
||||||
|
if ch.is_a?(Fixnum)
|
||||||
|
# Ruby 1.8
|
||||||
|
if (ch.chr rescue '') =~ /[[:print:]]/
|
||||||
|
ch = ch.chr
|
||||||
|
elsif (nch = num_unicode_bytes(ch)) > 1
|
||||||
|
chs = [ch]
|
||||||
|
(nch - 1).times do |i|
|
||||||
|
chs << C.getch
|
||||||
|
end
|
||||||
# UTF-8 TODO Ruby 1.8
|
# UTF-8 TODO Ruby 1.8
|
||||||
if chs.length > 1
|
|
||||||
ch = chs.pack('C*').force_encoding('UTF-8')
|
ch = chs.pack('C*').force_encoding('UTF-8')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
upd = actions.fetch(ch, proc { |chr|
|
if ch.is_a?(String) && ch =~ /[[:print:]]/
|
||||||
if chr =~ /[[:print:]]/
|
input.insert cursor, ch
|
||||||
input.insert cursor, chr
|
|
||||||
cursor += 1
|
cursor += 1
|
||||||
end
|
end
|
||||||
}).call(ch)
|
}).call(ch)
|
||||||
|
Loading…
Reference in New Issue
Block a user