Use the new `Doc:get_indent_info` throughout `core`

This commit is contained in:
Guldoman 2021-11-20 03:20:49 +01:00
parent 30d1bb097f
commit ebc05faf34
No known key found for this signature in database
GPG Key ID: C08A498EC7F1AFDD
4 changed files with 19 additions and 24 deletions

View File

@ -16,14 +16,6 @@ local function doc()
end end
local function get_indent_string()
if config.tab_type == "hard" then
return "\t"
end
return string.rep(" ", config.indent_size)
end
local function doc_multiline_selections(sort) local function doc_multiline_selections(sort)
local iter, state, idx, line1, col1, line2, col2 = doc():get_selections(sort) local iter, state, idx, line1, col1, line2, col2 = doc():get_selections(sort)
return function() return function()
@ -147,11 +139,12 @@ local commands = {
end, end,
["doc:backspace"] = function() ["doc:backspace"] = function()
local _, indent_size = doc():get_indent_info()
for idx, line1, col1, line2, col2 in doc():get_selections() do for idx, line1, col1, line2, col2 in doc():get_selections() do
if line1 == line2 and col1 == col2 then if line1 == line2 and col1 == col2 then
local text = doc():get_text(line1, 1, line1, col1) local text = doc():get_text(line1, 1, line1, col1)
if #text >= config.indent_size and text:find("^ *$") then if #text >= indent_size and text:find("^ *$") then
doc():delete_to_cursor(idx, 0, -config.indent_size) doc():delete_to_cursor(idx, 0, -indent_size)
return return
end end
end end
@ -261,7 +254,7 @@ local commands = {
["doc:toggle-line-comments"] = function() ["doc:toggle-line-comments"] = function()
local comment = doc().syntax.comment local comment = doc().syntax.comment
if not comment then return end if not comment then return end
local indentation = get_indent_string() local indentation = doc():get_indent_string()
local comment_text = comment .. " " local comment_text = comment .. " "
for idx, line1, _, line2 in doc_multiline_selections(true) do for idx, line1, _, line2 in doc_multiline_selections(true) do
local uncomment = true local uncomment = true

View File

@ -494,19 +494,21 @@ end
function Doc:select_to(...) return self:select_to_cursor(nil, ...) end function Doc:select_to(...) return self:select_to_cursor(nil, ...) end
local function get_indent_string() function Doc:get_indent_string()
if config.tab_type == "hard" then local indent_type, indent_size = self:get_indent_info()
if indent_type == "hard" then
return "\t" return "\t"
end end
return string.rep(" ", config.indent_size) return string.rep(" ", indent_size)
end end
-- returns the size of the original indent, and the indent -- returns the size of the original indent, and the indent
-- in your config format, rounded either up or down -- in your config format, rounded either up or down
local function get_line_indent(line, rnd_up) function Doc:get_line_indent(line, rnd_up)
local _, e = line:find("^[ \t]+") local _, e = line:find("^[ \t]+")
local soft_tab = string.rep(" ", config.indent_size) local indent_type, indent_size = self:get_indent_info()
if config.tab_type == "hard" then local soft_tab = string.rep(" ", indent_size)
if indent_type == "hard" then
local indent = e and line:sub(1, e):gsub(soft_tab, "\t") or "" local indent = e and line:sub(1, e):gsub(soft_tab, "\t") or ""
return e, indent:gsub(" +", rnd_up and "\t" or "") return e, indent:gsub(" +", rnd_up and "\t" or "")
else else
@ -528,14 +530,14 @@ end
-- * if you are unindenting, the cursor will jump to the start of the line, -- * if you are unindenting, the cursor will jump to the start of the line,
-- and remove the appropriate amount of spaces (or a tab). -- and remove the appropriate amount of spaces (or a tab).
function Doc:indent_text(unindent, line1, col1, line2, col2) function Doc:indent_text(unindent, line1, col1, line2, col2)
local text = get_indent_string() local text = self:get_indent_string()
local _, se = self.lines[line1]:find("^[ \t]+") local _, se = self.lines[line1]:find("^[ \t]+")
local in_beginning_whitespace = col1 == 1 or (se and col1 <= se + 1) local in_beginning_whitespace = col1 == 1 or (se and col1 <= se + 1)
local has_selection = line1 ~= line2 or col1 ~= col2 local has_selection = line1 ~= line2 or col1 ~= col2
if unindent or has_selection or in_beginning_whitespace then if unindent or has_selection or in_beginning_whitespace then
local l1d, l2d = #self.lines[line1], #self.lines[line2] local l1d, l2d = #self.lines[line1], #self.lines[line2]
for line = line1, line2 do for line = line1, line2 do
local e, rnded = get_line_indent(self.lines[line], unindent) local e, rnded = self:get_line_indent(self.lines[line], unindent)
self:remove(line, 1, line, (e or 0) + 1) self:remove(line, 1, line, (e or 0) + 1)
self:insert(line, 1, self:insert(line, 1,
unindent and rnded:sub(1, #rnded - #text) or rnded .. text) unindent and rnded:sub(1, #rnded - #text) or rnded .. text)

View File

@ -424,8 +424,8 @@ end
function DocView:draw() function DocView:draw()
self:draw_background(style.background) self:draw_background(style.background)
local _, indent_size = self.doc:get_indent_info()
self:get_font():set_tab_size(config.indent_size) self:get_font():set_tab_size(indent_size)
local minline, maxline = self:get_visible_line_range() local minline, maxline = self:get_visible_line_range()
local lh = self:get_line_height() local lh = self:get_line_height()

View File

@ -107,9 +107,9 @@ function StatusView:get_items()
local dv = core.active_view local dv = core.active_view
local line, col = dv.doc:get_selection() local line, col = dv.doc:get_selection()
local dirty = dv.doc:is_dirty() local dirty = dv.doc:is_dirty()
local indent = dv.doc.indent_info local indent_type, indent_size, indent_confirmed = dv.doc:get_indent_info()
local indent_label = (indent and indent.type == "hard") and "tabs: " or "spaces: " local indent_label = (indent_type == "hard") and "tabs: " or "spaces: "
local indent_size = indent and tostring(indent.size) .. (indent.confirmed and "" or "*") or "unknown" local indent_size_str = tostring(indent_size) .. (indent_confirmed and "" or "*") or "unknown"
return { return {
dirty and style.accent or style.text, style.icon_font, "f", dirty and style.accent or style.text, style.icon_font, "f",