From 786d119e5c3e1174cf9c5fc838458d1c6a9d93c8 Mon Sep 17 00:00:00 2001 From: David JULIEN Date: Sun, 12 Feb 2023 22:30:25 +0100 Subject: [PATCH 1/2] [nvim] feat: shorten path in statusline if needed --- .config/nvim/lua/statusline.lua | 265 +++++++++++++++++--------------- 1 file changed, 145 insertions(+), 120 deletions(-) diff --git a/.config/nvim/lua/statusline.lua b/.config/nvim/lua/statusline.lua index e7207b4..b864704 100644 --- a/.config/nvim/lua/statusline.lua +++ b/.config/nvim/lua/statusline.lua @@ -12,7 +12,7 @@ local function gen_section(hl_string, items) out = out .. " " .. item end end - if out ~="" then + if out ~= "" then return hl_string .. out .. " " else return out @@ -22,56 +22,56 @@ end -- sensible names for vim modes local function get_mode(m) local mode_group = { - ["n"] = "Normal", - ["no"] = "O-Pending", - ["nov"] = "O-Pending", - ["noV"] = "O-Pending", - ["no"] = "O-Pending", - ["niI"] = "Normal", - ["niR"] = "Normal", - ["niV"] = "Normal", - ["v"] = "Visual", - ["V"] = "V-Line", - [""] = "V-Block", - ["s"] = "Select", - ["S"] = "S-Line", - [""] = "S-Block", - ["i"] = "Insert", - ["ic"] = "Insert", - ["ix"] = "Insert", - ["R"] = "Replace", - ["Rc"] = "Replace", - ["Rv"] = "V-Replace", - ["Rx"] = "Replace", - ["c"] = "Command", - ["cv"] = "Ex", - ["ce"] = "Ex", - ["r"] = "Prompt", - ["rm"] = "Prompt", - ["r?"] = "Prompt", - ["!"] = "Shell", - ["t"] = "Terminal", + ["n"] = "Normal", + ["no"] = "O-Pending", + ["nov"] = "O-Pending", + ["noV"] = "O-Pending", + ["no"] = "O-Pending", + ["niI"] = "Normal", + ["niR"] = "Normal", + ["niV"] = "Normal", + ["v"] = "Visual", + ["V"] = "V-Line", + [""] = "V-Block", + ["s"] = "Select", + ["S"] = "S-Line", + [""] = "S-Block", + ["i"] = "Insert", + ["ic"] = "Insert", + ["ix"] = "Insert", + ["R"] = "Replace", + ["Rc"] = "Replace", + ["Rv"] = "V-Replace", + ["Rx"] = "Replace", + ["c"] = "Command", + ["cv"] = "Ex", + ["ce"] = "Ex", + ["r"] = "Prompt", + ["rm"] = "Prompt", + ["r?"] = "Prompt", + ["!"] = "Shell", + ["t"] = "Terminal", } return mode_group[m] or "None" end local function get_mode_display_name(m) local mode = { - ["Normal"] = "[ NRM ]", - ["O-Pending"] = "[ OTR ]", - ["Visual"] = "[ VSL ]", - ["V-Line"] = "[ V·L ]", - ["V-Block"] = "[ V·B ]", - ["Select"] = "[ SEL ]", - ["S-Line"] = "[ S·L ]", - ["S-Block"] = "[ S·B ]", - ["Insert"] = "[ INS ]", - ["Replace"] = "[ RPL ]", - ["Command"] = "[ CMD ]", - ["Prompt"] = "[ PMT ]", - ["Shell"] = "[ SHL ]", - ["Terminal"] = "[ TRM ]", - ["None"] = "[ --- ]" + ["Normal"] = "[ NRM ]", + ["O-Pending"] = "[ OTR ]", + ["Visual"] = "[ VSL ]", + ["V-Line"] = "[ V·L ]", + ["V-Block"] = "[ V·B ]", + ["Select"] = "[ SEL ]", + ["S-Line"] = "[ S·L ]", + ["S-Block"] = "[ S·B ]", + ["Insert"] = "[ INS ]", + ["Replace"] = "[ RPL ]", + ["Command"] = "[ CMD ]", + ["Prompt"] = "[ PMT ]", + ["Shell"] = "[ SHL ]", + ["Terminal"] = "[ TRM ]", + ["None"] = "[ --- ]" } return mode[m] end @@ -79,25 +79,48 @@ end -- get the highlight group for a mode group local function get_mode_color(m) local color = { - ["Normal"] = "%#NormalMode#", - ["O-Pending"] = "%#NormalMode#", - ["Visual"] = "%#VisualMode#", - ["V-Line"] = "%#VisualMode#", - ["V-Block"] = "%#VisualMode#", - ["Select"] = "%#NormalMode#", - ["S-Line"] = "%#NormalMode#", - ["S-Block"] = "%#NormalMode#", - ["Insert"] = "%#InsertMode#", - ["Replace"] = "%#ReplaceMode#", - ["Command"] = "%#CommandMode#", - ["Prompt"] = "%#NormalMode#", - ["Shell"] = "%#NormalMode#", - ["Terminal"] = "%#NormalMode#", - ["None"] = "%#NormalMode#" + ["Normal"] = "%#NormalMode#", + ["O-Pending"] = "%#NormalMode#", + ["Visual"] = "%#VisualMode#", + ["V-Line"] = "%#VisualMode#", + ["V-Block"] = "%#VisualMode#", + ["Select"] = "%#NormalMode#", + ["S-Line"] = "%#NormalMode#", + ["S-Block"] = "%#NormalMode#", + ["Insert"] = "%#InsertMode#", + ["Replace"] = "%#ReplaceMode#", + ["Command"] = "%#CommandMode#", + ["Prompt"] = "%#NormalMode#", + ["Shell"] = "%#NormalMode#", + ["Terminal"] = "%#NormalMode#", + ["None"] = "%#NormalMode#" } return color[m] end +-- from https://github.com/nvim-lualine/lualine.nvim/blob/master/lua/lualine/components/filename.lua +local function shorten_path(path, max_len) + local sep = '/' + local len = #path + if len <= max_len then + return path + end + + local segments = vim.split(path, sep) + for idx = 1, #segments - 1 do + if len <= max_len then + break + end + + local segment = segments[idx] + local shortened = segment:sub(1, vim.startswith(segment, '.') and 2 or 1) + segments[idx] = shortened + len = len - (#segment - #shortened) + end + + return table.concat(segments, sep) +end + -- from https://github.com/nvim-lua/lsp-status.nvim/blob/master/lua/lsp-status/diagnostics.lua local function get_lsp_diagnostics() local result = {} @@ -121,80 +144,82 @@ local function get_lsp_diagnostics() end local function process_diagnostics(prefix, n, hl) -if n > 0 then - return hl .. prefix .. n -else - return "" -end + if n > 0 then + return hl .. prefix .. n + else + return "" + end end local function spell_check() -if vim.wo.spell then - local lang = vim.o.spelllang - return "[SPELL=" .. lang .. "]" -else - return "" -end + if vim.wo.spell then + local lang = vim.o.spelllang + return "[SPELL=" .. lang .. "]" + else + return "" + end end local function statusline_focused() -local diagnostics = get_lsp_diagnostics() -local mode = vim.fn.mode() -local mg = get_mode(mode) -local accent_color = get_mode_color(mg) + local file = vim.fn.expand("%:p:~") + local diagnostics = get_lsp_diagnostics() + local mode = vim.fn.mode() + local mg = get_mode(mode) + local accent_color = get_mode_color(mg) + local winwidth = vim.fn.winwidth(0) -local left = table.concat { - gen_section(accent_color, {get_mode_display_name(mg)}), - gen_section("%#Middle#", {"%f"}), - gen_section("%#Bottom#", {"%m", "%r"}), - gen_section( - "%#Alert#", - { - process_diagnostics( - globals.sign_error .. " ", - diagnostics.error, - "%#DiagnosticVirtualTextError#" - ), - process_diagnostics( - globals.sign_warn .. " ", - diagnostics.warn, - "%#DiagnosticVirtualTextWarn#" - ), - process_diagnostics( - globals.sign_info .. " ", - diagnostics.info, - "%#DiagnosticVirtualTextInfo#" - ) - } - ) -} -local right = table.concat { - gen_section( - "%#Bottom#", - { - spell_check(), - vim.bo.filetype - } - ), - gen_section("%#Middle#", {"%03.p%%"}), - gen_section("%#Top#", {"-%03.c-"}) -} + local left = table.concat { + gen_section(accent_color, { get_mode_display_name(mg) }), + gen_section("%#Middle#", { shorten_path(file, winwidth / 3) }), + gen_section("%#Bottom#", { "%m", "%r" }), + gen_section( + "%#Alert#", + { + process_diagnostics( + globals.sign_error .. " ", + diagnostics.error, + "%#DiagnosticVirtualTextError#" + ), + process_diagnostics( + globals.sign_warn .. " ", + diagnostics.warn, + "%#DiagnosticVirtualTextWarn#" + ), + process_diagnostics( + globals.sign_info .. " ", + diagnostics.info, + "%#DiagnosticVirtualTextInfo#" + ) + } + ) + } + local right = table.concat { + gen_section( + "%#Bottom#", + { + spell_check(), + vim.bo.filetype + } + ), + gen_section("%#Middle#", { "%03.p%%" }), + gen_section("%#Top#", { "-%03.c-" }) + } -return table.concat { - left, - "%#Statusline#", - "%=", - right -} + return table.concat { + left, + "%#Statusline#", + "%=", + right + } end local function statusline_not_focused() return table.concat { - gen_section("%#StatuslineNF#", {"%f", "%m"}), + gen_section("%#StatuslineNF#", { "%f", "%m" }), "%=", - gen_section("%#StatuslineNF#", {"%03.p%%"}), - gen_section("%#StatuslineNF#", {"-%03.c-"}) + gen_section("%#StatuslineNF#", { "%03.p%%" }), + gen_section("%#StatuslineNF#", { "-%03.c-" }) } end From cdd3b5024888215e5c25a208c2a26306e6016d72 Mon Sep 17 00:00:00 2001 From: David JULIEN Date: Mon, 13 Feb 2023 09:49:14 +0100 Subject: [PATCH 2/2] [nvim] fix: shorten filenames in unfocused buffers 786d119 shortened the filename for the current buffer, but didn't change the filename in other buffers --- .config/nvim/lua/statusline.lua | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/.config/nvim/lua/statusline.lua b/.config/nvim/lua/statusline.lua index b864704..a383585 100644 --- a/.config/nvim/lua/statusline.lua +++ b/.config/nvim/lua/statusline.lua @@ -215,8 +215,14 @@ local function statusline_focused() end local function statusline_not_focused() + local bufnr = vim.fn.winbufnr(vim.g.statusline_winid) + local file = vim.fn.expand("#" .. bufnr .. ":p:~") + local winwidth = vim.fn.winwidth(0) return table.concat { - gen_section("%#StatuslineNF#", { "%f", "%m" }), + gen_section("%#StatuslineNF#", { + shorten_path(file, winwidth / 3), + "%m" + }), "%=", gen_section("%#StatuslineNF#", { "%03.p%%" }), gen_section("%#StatuslineNF#", { "-%03.c-" })