Compare commits
3 Commits
v0.2.0
...
79499e898c
| Author | SHA1 | Date | |
|---|---|---|---|
| 79499e898c | |||
| de01a95cdc | |||
| c87cc7c387 |
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
*.src.rock
|
||||||
@@ -108,14 +108,24 @@ function M.setup()
|
|||||||
if from_cn < 32 or from_cn > 126 then return end
|
if from_cn < 32 or from_cn > 126 then return end
|
||||||
local from_c = vim.fn.nr2char(from_cn)
|
local from_c = vim.fn.nr2char(from_cn)
|
||||||
local from = surrounds[from_c] or { left = from_c, right = from_c }
|
local from = surrounds[from_c] or { left = from_c, right = from_c }
|
||||||
|
local function get_fresh_arange()
|
||||||
|
local arange = Range.from_text_object('a' .. from_c, { user_defined = true })
|
||||||
|
if arange == nil then return nil end
|
||||||
|
if from_c == 'q' then
|
||||||
|
from.left = arange.start:char()
|
||||||
|
from.right = arange.stop:char()
|
||||||
|
end
|
||||||
|
return arange
|
||||||
|
end
|
||||||
|
|
||||||
local arange = Range.from_text_object('a' .. from_c, { user_defined = true })
|
local arange = get_fresh_arange()
|
||||||
if arange == nil then return nil end
|
if arange == nil then return nil end
|
||||||
|
|
||||||
local hl_info1 = Range.new(arange.start, arange.start, 'v'):highlight('IncSearch', { priority = 999 })
|
local hl_info1 = Range.new(arange.start, arange.start, 'v'):highlight('IncSearch', { priority = 999 })
|
||||||
local hl_info2 = Range.new(arange.stop, arange.stop, 'v'):highlight('IncSearch', { priority = 999 })
|
local hl_info2 = Range.new(arange.stop, arange.stop, 'v'):highlight('IncSearch', { priority = 999 })
|
||||||
local hl_clear = function()
|
local hl_clear = function()
|
||||||
hl_info1.clear()
|
if hl_info1 then hl_info1.clear() end
|
||||||
hl_info2.clear()
|
if hl_info2 then hl_info2.clear() end
|
||||||
end
|
end
|
||||||
|
|
||||||
local to = prompt_for_bounds()
|
local to = prompt_for_bounds()
|
||||||
@@ -123,6 +133,10 @@ function M.setup()
|
|||||||
if to == nil then return end
|
if to == nil then return end
|
||||||
|
|
||||||
vim_repeat.run(function()
|
vim_repeat.run(function()
|
||||||
|
-- Re-fetch the arange, just in case this action is being repeated:
|
||||||
|
arange = get_fresh_arange()
|
||||||
|
if arange == nil then return nil end
|
||||||
|
|
||||||
if from_c == 't' then
|
if from_c == 't' then
|
||||||
-- For tags, we want to replace the inner text, not the tag:
|
-- For tags, we want to replace the inner text, not the tag:
|
||||||
local irange = Range.from_text_object('i' .. from_c, { user_defined = true })
|
local irange = Range.from_text_object('i' .. from_c, { user_defined = true })
|
||||||
@@ -219,11 +233,11 @@ function M.setup()
|
|||||||
bounds = _G.my_surround_bounds
|
bounds = _G.my_surround_bounds
|
||||||
else
|
else
|
||||||
local prompted_bounds = prompt_for_bounds()
|
local prompted_bounds = prompt_for_bounds()
|
||||||
if prompted_bounds == nil then return hl_info.clear() end
|
if prompted_bounds == nil and hl_info then return hl_info.clear() end
|
||||||
bounds = prompted_bounds
|
if prompted_bounds then bounds = prompted_bounds end
|
||||||
end
|
end
|
||||||
|
|
||||||
hl_info.clear()
|
if hl_info then hl_info.clear() end
|
||||||
do_surround(range, bounds)
|
do_surround(range, bounds)
|
||||||
-- selene: allow(global_usage)
|
-- selene: allow(global_usage)
|
||||||
_G.my_surround_bounds = nil
|
_G.my_surround_bounds = nil
|
||||||
|
|||||||
@@ -127,7 +127,7 @@ function Range.from_text_object(text_obj, opts)
|
|||||||
|
|
||||||
local prev_on_yank_enabled = on_yank_enabled
|
local prev_on_yank_enabled = on_yank_enabled
|
||||||
on_yank_enabled = false
|
on_yank_enabled = false
|
||||||
vim.cmd.normal {
|
vim.cmd {
|
||||||
cmd = 'normal',
|
cmd = 'normal',
|
||||||
bang = not opts.user_defined,
|
bang = not opts.user_defined,
|
||||||
args = { '""y' .. text_obj },
|
args = { '""y' .. text_obj },
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
local M = {}
|
local M = {}
|
||||||
|
|
||||||
local function _normal(cmd) vim.cmd.normal { cmd = 'normal', args = { cmd }, bang = true } end
|
local function _normal(cmd) vim.cmd { cmd = 'normal', args = { cmd }, bang = true } end
|
||||||
|
|
||||||
M.native_repeat = function() _normal '.' end
|
M.native_repeat = function() _normal '.' end
|
||||||
M.native_undo = function() _normal 'u' end
|
M.native_undo = function() _normal 'u' end
|
||||||
|
|||||||
24
u.nvim-0.2.0-1.rockspec
Normal file
24
u.nvim-0.2.0-1.rockspec
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
package = "u.nvim"
|
||||||
|
version = "0.2.0-1"
|
||||||
|
source = {
|
||||||
|
url = "git+https://github.com/jrop/u.nvim"
|
||||||
|
}
|
||||||
|
description = {
|
||||||
|
summary = "nvim – a powerful Lua library designed to enhance your text manipulation experience in NeoVim, focusing primarily on a context-aware \"Range\" utility.",
|
||||||
|
detailed = "Welcome to u.nvim – a powerful Lua library designed to enhance your text manipulation experience in NeoVim, focusing primarily on a context-aware \"Range\" utility. This utility allows you to work efficiently with text selections based on various conditions, in a variety of contexts, making coding and editing more intuitive and productive.",
|
||||||
|
homepage = "https://github.com/jrop/u.nvim",
|
||||||
|
license = "MIT"
|
||||||
|
}
|
||||||
|
build = {
|
||||||
|
type = "builtin",
|
||||||
|
modules = {
|
||||||
|
["u.buffer"] = "lua/u/buffer.lua",
|
||||||
|
["u.codewriter"] = "lua/u/codewriter.lua",
|
||||||
|
["u.opkeymap"] = "lua/u/opkeymap.lua",
|
||||||
|
["u.pos"] = "lua/u/pos.lua",
|
||||||
|
["u.range"] = "lua/u/range.lua",
|
||||||
|
["u.repeat"] = "lua/u/repeat.lua",
|
||||||
|
["u.state"] = "lua/u/state.lua",
|
||||||
|
["u.utils"] = "lua/u/utils.lua"
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user