Compare commits
5 Commits
dbcf65f6f5
...
1449ff5d5c
| Author | SHA1 | Date | |
|---|---|---|---|
| 1449ff5d5c | |||
| 35046d1269 | |||
| 26cbc9b667 | |||
| 967e9750d9 | |||
| 0949fcfb49 |
@@ -263,6 +263,7 @@ fi
|
|||||||
exec fzf --query "$3" \
|
exec fzf --query "$3" \
|
||||||
--prompt "$prompt" \
|
--prompt "$prompt" \
|
||||||
--header-label "$label" \
|
--header-label "$label" \
|
||||||
|
--multi \
|
||||||
--ansi \
|
--ansi \
|
||||||
--delimiter : \
|
--delimiter : \
|
||||||
--ghost ' (Use alt-? for help)' \
|
--ghost ' (Use alt-? for help)' \
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ local lex = lexer.new(..., {inherit = lexer.load('go')})
|
|||||||
|
|
||||||
local open_brace = lex:tag(lexer.OPERATOR, P('{'))
|
local open_brace = lex:tag(lexer.OPERATOR, P('{'))
|
||||||
local close_brace = lex:tag(lexer.OPERATOR, P('}'))
|
local close_brace = lex:tag(lexer.OPERATOR, P('}'))
|
||||||
local backtick = lex:tag(lexer.STRING, P('`'))
|
local backtick = lex:tag(lexer.CODE, P('`'))
|
||||||
local ws = lex:get_rule('whitespace')
|
local ws = lex:get_rule('whitespace')
|
||||||
|
|
||||||
local tpl = lexer.new("template")
|
local tpl = lexer.new("template")
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
-- Eight-color scheme
|
-- Eight-color scheme
|
||||||
local lexers = vis.lexers
|
local lexers = vis.lexers
|
||||||
lexers.STYLE_DEFAULT ='back:#dae4f1,fore:#1f212e'
|
lexers.STYLE_DEFAULT ='back:#f2f2f3,#e0e5eb,fore:#1f212e'
|
||||||
lexers.STYLE_NOTHING = ''
|
lexers.STYLE_NOTHING = ''
|
||||||
lexers.STYLE_ATTRIBUTE = 'fore:#a1a3aa,bold'
|
lexers.STYLE_ATTRIBUTE = 'fore:#a1a3aa,bold'
|
||||||
lexers.STYLE_CLASS = 'fore:yellow,bold'
|
lexers.STYLE_CLASS = 'fore:yellow,bold'
|
||||||
@@ -21,7 +21,7 @@ lexers.STYLE_TAG = 'fore:#705943,bold'
|
|||||||
lexers.STYLE_TYPE = 'fore:#7461d1,bold'
|
lexers.STYLE_TYPE = 'fore:#7461d1,bold'
|
||||||
lexers.STYLE_VARIABLE = 'fore:#8c5eba,bold'
|
lexers.STYLE_VARIABLE = 'fore:#8c5eba,bold'
|
||||||
lexers.STYLE_WHITESPACE = ''
|
lexers.STYLE_WHITESPACE = ''
|
||||||
lexers.STYLE_EMBEDDED = 'back:#2d3353,bold'
|
lexers.STYLE_EMBEDDED = 'back:#e0e5eb,bold'
|
||||||
lexers.STYLE_IDENTIFIER = ''
|
lexers.STYLE_IDENTIFIER = ''
|
||||||
|
|
||||||
lexers.STYLE_LINENUMBER = ''
|
lexers.STYLE_LINENUMBER = ''
|
||||||
|
|||||||
@@ -49,10 +49,16 @@ local function nil_or_tonumber(s)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function open_file_pos(line, open_cmd)
|
local function open_file_pos(line, open_cmd)
|
||||||
local iter = string.gmatch(line, '[^:]+')
|
local iter = line:gmatch('[^:]+')
|
||||||
local file = iter()
|
local file = iter()
|
||||||
local line_num = nil_or_tonumber(iter())
|
local ln = iter()
|
||||||
local col = nil_or_tonumber(iter()) or 1
|
local col = nil_or_tonumber(iter()) or 1
|
||||||
|
local i = ln and ln:find(' ')
|
||||||
|
if i then
|
||||||
|
ln = ln:sub(0, i)
|
||||||
|
col = 1
|
||||||
|
end
|
||||||
|
local line_num = nil_or_tonumber(ln)
|
||||||
if open_cmd ~= 'e' or vis.win.file ~= file then
|
if open_cmd ~= 'e' or vis.win.file ~= file then
|
||||||
open_file(file, open_cmd)
|
open_file(file, open_cmd)
|
||||||
end
|
end
|
||||||
@@ -61,10 +67,13 @@ local function open_file_pos(line, open_cmd)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function open_file_current_line(open_cmd)
|
local function open_file_current_line(open_cmd, keys)
|
||||||
local line = vis.win.file.lines[vis.win.selection.line]
|
local line = vis.win.file.lines[vis.win.selection.line]
|
||||||
vis:info(line)
|
vis:info(line)
|
||||||
open_file_pos(line)
|
if keys then
|
||||||
|
vis:feedkeys(keys)
|
||||||
|
end
|
||||||
|
open_file_pos(line, open_cmd)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function escape_and_quoted(s)
|
local function escape_and_quoted(s)
|
||||||
@@ -84,23 +93,33 @@ end
|
|||||||
|
|
||||||
local function fzf_sh(arg)
|
local function fzf_sh(arg)
|
||||||
action = function(out)
|
action = function(out)
|
||||||
|
if (out:find('\n') or #out) == #out then
|
||||||
open_file_pos(out, vis.win.file.modified and 'o' or 'e')
|
open_file_pos(out, vis.win.file.modified and 'o' or 'e')
|
||||||
|
else
|
||||||
|
vis:message(out)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
local home = os.getenv('HOME')
|
local home = os.getenv('HOME')
|
||||||
local path = vis.win.file.path or ''
|
local path = vis.win.file.path or ''
|
||||||
local dir = path:match('^.*/') or ''
|
local dir = path:match('^.*/') or ''
|
||||||
local reg = ''
|
local reg = ''
|
||||||
if reg ~= '"' then
|
if vis.register ~= '"' then
|
||||||
reg = string.gsub(vis.registers[vis.register][1], '%z', '')
|
reg = string.gsub(vis.registers[vis.register][1], '%z', '')
|
||||||
end
|
end
|
||||||
local cmd = home .. '/.config/vis/fzf.sh ' .. escape_and_quoted(arg) .. ' ' .. escape_and_quoted(dir) .. ' ' .. escape_and_quoted(reg)
|
local cmd = home ..
|
||||||
|
'/.config/vis/fzf.sh ' ..
|
||||||
|
escape_and_quoted(arg) .. ' ' .. escape_and_quoted(dir) .. ' ' .. escape_and_quoted(reg)
|
||||||
cmd_action(cmd, action)
|
cmd_action(cmd, action)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function search(cmd, action)
|
local function search(cmd, action)
|
||||||
if action == nil then
|
if action == nil then
|
||||||
action = function(out)
|
action = function(out)
|
||||||
|
if (out:find('\n') or #s) == #s then
|
||||||
open_file_pos(out, 'e')
|
open_file_pos(out, 'e')
|
||||||
|
else
|
||||||
|
vis:message(out)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if cmd:match('^fzf ') and vis.register ~= '"' then
|
if cmd:match('^fzf ') and vis.register ~= '"' then
|
||||||
@@ -187,17 +206,27 @@ local ripgrep = 'rg --column --line-number --color=always --smart-case'
|
|||||||
|
|
||||||
local function close_prev_win()
|
local function close_prev_win()
|
||||||
vis:feedkeys('<vis-window-prev>')
|
vis:feedkeys('<vis-window-prev>')
|
||||||
if not vis.win:close() then
|
if vis.win == win then
|
||||||
vis:feedkeys('<vis-window-next>')
|
vis:info('Last window')
|
||||||
|
elseif not vis.win:close() then
|
||||||
|
if vis.win.file.modified then
|
||||||
vis:info('No write since last change')
|
vis:info('No write since last change')
|
||||||
|
else
|
||||||
|
vis:command('q')
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function close_next_win()
|
local function close_next_win()
|
||||||
vis:feedkeys('<vis-window-next>')
|
vis:feedkeys('<vis-window-next>')
|
||||||
if not vis.win:close() then
|
if vis.win == win then
|
||||||
vis:feedkeys('<vis-window-prev>')
|
vis:info('Last window')
|
||||||
|
elseif not vis.win:close() then
|
||||||
|
if vis.win.file.modified then
|
||||||
vis:info('No write since last change')
|
vis:info('No write since last change')
|
||||||
|
else
|
||||||
|
vis:command('q')
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -266,11 +295,23 @@ vis.events.subscribe(vis.events.INIT, function()
|
|||||||
vis:command('fzfmru')
|
vis:command('fzfmru')
|
||||||
end, 'fzf recent')
|
end, 'fzf recent')
|
||||||
|
|
||||||
vis:map(vis.modes.NORMAL, 'gf', function()
|
vis:map(vis.modes.NORMAL, ' w', function()
|
||||||
open_file_current_line('o')
|
open_file_current_line('e')
|
||||||
end, 'open file from current line (with line and col')
|
end, 'open file from current line in current window (with optional line and col)')
|
||||||
|
|
||||||
vis:map(vis.modes.NORMAL, ' cd', function()
|
vis:map(vis.modes.NORMAL, ' o', function()
|
||||||
|
open_file_current_line('o')
|
||||||
|
end, 'open file from current line in new window (with optional line and col)')
|
||||||
|
|
||||||
|
vis:map(vis.modes.NORMAL, ' k', function()
|
||||||
|
open_file_current_line('e', '<vis-window-prev>')
|
||||||
|
end, 'open file from current line in above window (with optional line and col)')
|
||||||
|
|
||||||
|
vis:map(vis.modes.NORMAL, ' j', function()
|
||||||
|
open_file_current_line('e', '<vis-window-next>')
|
||||||
|
end, 'open file from current line in below window (with optional line and col)')
|
||||||
|
|
||||||
|
vis:map(vis.modes.NORMAL, ' c', function()
|
||||||
search('zoxide query -l | fzf', function(path)
|
search('zoxide query -l | fzf', function(path)
|
||||||
vis:command('cd ' .. path)
|
vis:command('cd ' .. path)
|
||||||
end)
|
end)
|
||||||
|
|||||||
@@ -80,7 +80,7 @@ st.color13: #8f248f
|
|||||||
st.color14: #509595
|
st.color14: #509595
|
||||||
st.color15: #dbdff0
|
st.color15: #dbdff0
|
||||||
#else
|
#else
|
||||||
st.background: #dae4f1
|
st.background: #f2f2f3
|
||||||
st.foreground: #1f212e
|
st.foreground: #1f212e
|
||||||
st.cursorColor: #bf8040
|
st.cursorColor: #bf8040
|
||||||
st.reverse-cursor: #1f212e
|
st.reverse-cursor: #1f212e
|
||||||
|
|||||||
Reference in New Issue
Block a user