Merge pull request #334 from adamharrison/find-fixes

Find Improvements
This commit is contained in:
Adam 2021-07-16 17:53:41 -04:00 committed by GitHub
commit 69da9655d1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 19 additions and 19 deletions

View File

@ -10,27 +10,27 @@ local StatusView = require "core.statusview"
local max_last_finds = 50 local max_last_finds = 50
local last_finds, last_view, last_fn, last_text, last_sel local last_finds, last_view, last_fn, last_text, last_sel
local case_insensitive = config.find_case_insensitive or false local case_sensitive = config.find_case_sensitive or false
local plain = config.find_plain or false local find_regex = config.find_regex or false
local function doc() local function doc()
return last_view and last_view.doc or core.active_view.doc return core.active_view:is(DocView) and core.active_view.doc or last_view.doc
end end
local function get_find_tooltip() local function get_find_tooltip()
local rf = keymap.get_binding("find-replace:repeat-find") local rf = keymap.get_binding("find-replace:repeat-find")
local ti = keymap.get_binding("find-replace:toggle-insensitivity") local ti = keymap.get_binding("find-replace:toggle-sensitivity")
local tr = keymap.get_binding("find-replace:toggle-plain") local tr = keymap.get_binding("find-replace:toggle-regex")
return (plain and "[Plain] " or "") .. return (find_regex and "[Regex] " or "") ..
(case_insensitive and "[Insensitive] " or "") .. (case_sensitive and "[Sensitive] " or "") ..
(rf and ("Press " .. rf .. " to select the next match.") or "") .. (rf and ("Press " .. rf .. " to select the next match.") or "") ..
(ti and (" " .. ti .. " toggles case sensitivity.") or "") .. (ti and (" " .. ti .. " toggles case sensitivity.") or "") ..
(tr and (" " .. tr .. " toggles plain find.") or "") (tr and (" " .. tr .. " toggles regex find.") or "")
end end
local function update_preview(sel, search_fn, text) local function update_preview(sel, search_fn, text)
local ok, line1, col1, line2, col2 = local ok, line1, col1, line2, col2 =
pcall(search_fn, last_view.doc, sel[1], sel[2], text, case_insensitive, plain) pcall(search_fn, last_view.doc, sel[1], sel[2], text, case_sensitive, find_regex)
if ok and line1 and text ~= "" then if ok and line1 and text ~= "" then
last_view.doc:set_selection(line2, col2, line1, col1) last_view.doc:set_selection(line2, col2, line1, col1)
last_view:scroll_to_line(line2, true) last_view:scroll_to_line(line2, true)
@ -105,15 +105,15 @@ command.add(has_selection, {
command.add("core.docview", { command.add("core.docview", {
["find-replace:find"] = function() ["find-replace:find"] = function()
find("Find Text", function(doc, line, col, text, case_insensitive, plain) find("Find Text", function(doc, line, col, text, case_sensitive, find_regex)
local opt = { wrap = true, no_case = case_insensitive, regex = not plain } local opt = { wrap = true, no_case = not case_sensitive, regex = find_regex }
return search.find(doc, line, col, text, opt) return search.find(doc, line, col, text, opt)
end) end)
end, end,
["find-replace:replace"] = function() ["find-replace:replace"] = function()
replace("Text", doc():get_text(doc():get_selection(true)), function(text, old, new) replace("Text", doc():get_text(doc():get_selection(true)), function(text, old, new)
if plain then if not find_regex then
return text:gsub(old:gsub("%W", "%%%1"), new:gsub("%%", "%%%%"), nil) return text:gsub(old:gsub("%W", "%%%1"), new:gsub("%%", "%%%%"), nil)
end end
local result, matches = regex.gsub(regex.compile(old), text, new) local result, matches = regex.gsub(regex.compile(old), text, new)
@ -150,7 +150,7 @@ command.add(valid_for_finding, {
core.error("No find to continue from") core.error("No find to continue from")
else else
local sl1, sc1, sl2, sc2 = doc():get_selection(true) local sl1, sc1, sl2, sc2 = doc():get_selection(true)
local line1, col1, line2, col2 = last_fn(doc(), sl1, sc2, last_text, case_insensitive, plain) local line1, col1, line2, col2 = last_fn(doc(), sl1, sc2, last_text, case_sensitive, find_regex)
if line1 then if line1 then
if last_view.doc ~= doc() then if last_view.doc ~= doc() then
last_finds = {} last_finds = {}
@ -177,14 +177,14 @@ command.add(valid_for_finding, {
}) })
command.add("core.commandview", { command.add("core.commandview", {
["find-replace:toggle-insensitivity"] = function() ["find-replace:toggle-sensitivity"] = function()
case_insensitive = not case_insensitive case_sensitive = not case_sensitive
core.status_view:show_tooltip(get_find_tooltip()) core.status_view:show_tooltip(get_find_tooltip())
update_preview(last_sel, last_fn, last_text) update_preview(last_sel, last_fn, last_text)
end, end,
["find-replace:toggle-plain"] = function() ["find-replace:toggle-regex"] = function()
plain = not plain find_regex = not find_regex
core.status_view:show_tooltip(get_find_tooltip()) core.status_view:show_tooltip(get_find_tooltip())
update_preview(last_sel, last_fn, last_text) update_preview(last_sel, last_fn, last_text)
end end

View File

@ -137,8 +137,8 @@ keymap.add_direct {
["ctrl+r"] = "find-replace:replace", ["ctrl+r"] = "find-replace:replace",
["f3"] = "find-replace:repeat-find", ["f3"] = "find-replace:repeat-find",
["shift+f3"] = "find-replace:previous-find", ["shift+f3"] = "find-replace:previous-find",
["ctrl+i"] = "find-replace:toggle-insensitivity", ["ctrl+i"] = "find-replace:toggle-sensitivity",
["ctrl+shift+i"] = "find-replace:toggle-plain", ["ctrl+shift+i"] = "find-replace:toggle-regex",
["ctrl+g"] = "doc:go-to-line", ["ctrl+g"] = "doc:go-to-line",
["ctrl+s"] = "doc:save", ["ctrl+s"] = "doc:save",
["ctrl+shift+s"] = "doc:save-as", ["ctrl+shift+s"] = "doc:save-as",