WIP
This commit is contained in:
parent
e132a1a754
commit
874b5f2f42
149
lua/argonaut.lua
149
lua/argonaut.lua
@ -22,16 +22,21 @@ local function get_cursor_pos()
|
||||
return {row = row, col = col}
|
||||
end
|
||||
|
||||
local function find_range(brace_pair)
|
||||
local function filter()
|
||||
local pos = get_cursor_pos()
|
||||
local attr = vim.fn.synIDattr(vim.fn.synID(pos.row, pos.col, false), 'name')
|
||||
return attr:find('String$')
|
||||
local function is_literal(pos)
|
||||
if not pos then
|
||||
pos = get_cursor_pos()
|
||||
end
|
||||
|
||||
local row1, col1 = unpack(vim.fn.searchpairpos(brace_pair[1], '', brace_pair[2], 'Wnb', filter))
|
||||
local syn_id = vim.fn.synID(pos.row, pos.col, false)
|
||||
local syn_attr = vim.fn.synIDattr(syn_id, 'name')
|
||||
|
||||
return syn_attr:find('String$')
|
||||
end
|
||||
|
||||
local function find_range(brace_pair)
|
||||
local row1, col1 = unpack(vim.fn.searchpairpos(brace_pair[1], '', brace_pair[2], 'Wnb', is_literal))
|
||||
if row1 > 0 and col1 > 0 then
|
||||
local row2, col2 = unpack(vim.fn.searchpairpos(brace_pair[1], '', brace_pair[2], 'Wcn', filter))
|
||||
local row2, col2 = unpack(vim.fn.searchpairpos(brace_pair[1], '', brace_pair[2], 'Wcn', is_literal))
|
||||
if row2 > 0 and col2 > 0 then
|
||||
return {
|
||||
brace_pair = brace_pair,
|
||||
@ -44,7 +49,7 @@ local function find_range(brace_pair)
|
||||
end
|
||||
end
|
||||
|
||||
local function find_ranges(brace_pairs)
|
||||
local function find_all_ranges(brace_pairs)
|
||||
local ranges = {}
|
||||
for _, brace_pair in ipairs(brace_pairs) do
|
||||
local range = find_range(brace_pair)
|
||||
@ -58,40 +63,120 @@ local function find_ranges(brace_pairs)
|
||||
end
|
||||
end
|
||||
|
||||
local function compare_ranges(range1, range2)
|
||||
local pos = get_cursor_pos()
|
||||
local function find_closest_range(brace_pairs)
|
||||
local function compare_ranges(range1, range2)
|
||||
local pos = get_cursor_pos()
|
||||
|
||||
local row_diff1 = pos.row - range1.row1
|
||||
local row_diff2 = pos.row - range2.row1
|
||||
if row_diff1 < row_diff2 then
|
||||
return -1
|
||||
elseif row_diff1 > row_diff2 then
|
||||
return 1
|
||||
local row_diff1 = pos.row - range1.row1
|
||||
local row_diff2 = pos.row - range2.row1
|
||||
if row_diff1 < row_diff2 then
|
||||
return -1
|
||||
elseif row_diff1 > row_diff2 then
|
||||
return 1
|
||||
end
|
||||
|
||||
local col_diff1 = pos.col - range1.col1
|
||||
local col_diff2 = pos.col - range2.col1
|
||||
if col_diff1 < col_diff2 then
|
||||
return -1
|
||||
elseif col_diff1 > col_diff2 then
|
||||
return 1
|
||||
end
|
||||
|
||||
return 0
|
||||
end
|
||||
|
||||
local col_diff1 = pos.col - range1.col1
|
||||
local col_diff2 = pos.col - range2.col1
|
||||
if col_diff1 < col_diff2 then
|
||||
return -1
|
||||
elseif col_diff1 > col_diff2 then
|
||||
return 1
|
||||
end
|
||||
|
||||
return 0
|
||||
end
|
||||
|
||||
local function find_range_closest(brace_pairs)
|
||||
local ranges = find_ranges(brace_pairs)
|
||||
local ranges = find_all_ranges(brace_pairs)
|
||||
if ranges then
|
||||
return vim.fn.sort(ranges, compare_ranges)[1]
|
||||
end
|
||||
end
|
||||
|
||||
local function parse_range(range)
|
||||
local elements = {}
|
||||
for row = range.row1, range.row2 do
|
||||
local line = vim.fn.getline(row)
|
||||
|
||||
local col1 = 0
|
||||
if row == range.row1 then
|
||||
col1 = range.col1 + 1
|
||||
end
|
||||
|
||||
local col2 = #line
|
||||
if row == range.row2 then
|
||||
col2 = range.col2 - 1
|
||||
end
|
||||
|
||||
for i = col1, col2 do
|
||||
table.insert(elements, {
|
||||
char = line:sub(i, i), ---@diagnostic disable-line: undefined-field
|
||||
literal = is_literal({row = row, col = i}),
|
||||
})
|
||||
end
|
||||
end
|
||||
|
||||
local params = {}
|
||||
local param = ''
|
||||
local flush_param = function()
|
||||
if #param > 0 then
|
||||
table.insert(params, param)
|
||||
param = ''
|
||||
end
|
||||
end
|
||||
|
||||
local brace_stack = {}
|
||||
local update_brace_stack = function(char)
|
||||
local brace_stack_size = #brace_stack
|
||||
|
||||
local brace_pairs_forward = {
|
||||
['('] = ')',
|
||||
['['] = ']',
|
||||
['{'] = '}',
|
||||
['<'] = '>'
|
||||
}
|
||||
local brace_pairs_backward = {
|
||||
[')'] = '(',
|
||||
[']'] = '[',
|
||||
['}'] = '{',
|
||||
['>'] = '<'
|
||||
}
|
||||
|
||||
if brace_stack_size > 0 and brace_stack[brace_stack_size] == brace_pairs_backward[char] then
|
||||
table.remove(brace_stack, brace_stack_size)
|
||||
elseif brace_pairs_forward[char] then
|
||||
table.insert(brace_stack, char)
|
||||
end
|
||||
end
|
||||
|
||||
if #elements > 0 then
|
||||
for _, element in ipairs(elements) do
|
||||
local concat = true
|
||||
if not element.literal then
|
||||
update_brace_stack(element.char)
|
||||
if #brace_stack == 0 and element.char == ',' then
|
||||
flush_param()
|
||||
concat = false
|
||||
end
|
||||
end
|
||||
|
||||
if concat then
|
||||
param = param .. element.char
|
||||
end
|
||||
end
|
||||
|
||||
flush_param()
|
||||
end
|
||||
|
||||
for _, p in ipairs(params) do
|
||||
print(p)
|
||||
end
|
||||
end
|
||||
|
||||
local function reflow()
|
||||
local brace_pairs = {{'(', ')'}, {'[', ']'}, {'{', '}'}, {'<', '>'}}
|
||||
local range = find_range_closest(brace_pairs)
|
||||
local brace_pairs = {{'(', ')'}, {'\\[', '\\]'}, {'{', '}'}, {'<', '>'}}
|
||||
local range = find_closest_range(brace_pairs)
|
||||
if range then
|
||||
print(range.brace_pair[1])
|
||||
parse_range(range)
|
||||
end
|
||||
end
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user