chore: formated with stylua (#32)

Apply initial stylua format

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
This commit is contained in:
github-actions[bot] 2021-09-04 00:28:20 +06:00 committed by GitHub
parent 4042e837f8
commit db448f41e6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
73 changed files with 1481 additions and 1261 deletions

View File

@ -28,10 +28,10 @@ local bubbles_theme = {
a = { fg = colors.white, bg = colors.black }, a = { fg = colors.white, bg = colors.black },
b = { fg = colors.white, bg = colors.black }, b = { fg = colors.white, bg = colors.black },
c = { fg = colors.black, bg = colors.black }, c = { fg = colors.black, bg = colors.black },
} },
} }
require'lualine'.setup { require('lualine').setup {
options = { options = {
theme = bubbles_theme, theme = bubbles_theme,
component_separators = '|', component_separators = '|',
@ -39,20 +39,14 @@ require'lualine'.setup {
}, },
sections = { sections = {
lualine_a = { lualine_a = {
{'mode', { 'mode', separator = { '', '' }, right_padding = 2 },
separator = {'', ''},
right_padding = 2,
}
}, },
lualine_b = { 'filename', 'branch' }, lualine_b = { 'filename', 'branch' },
lualine_c = { 'fileformat' }, lualine_c = { 'fileformat' },
lualine_x = {}, lualine_x = {},
lualine_y = { 'filetype', 'progress' }, lualine_y = { 'filetype', 'progress' },
lualine_z = { lualine_z = {
{'location', { 'location', separator = { '', '' }, left_padding = 2 },
separator = {'', ''},
left_padding = 2,
}
}, },
}, },
inactive_sections = { inactive_sections = {
@ -61,8 +55,8 @@ require'lualine'.setup {
lualine_c = {}, lualine_c = {},
lualine_x = {}, lualine_x = {},
lualine_y = {}, lualine_y = {},
lualine_z = {'location'} lualine_z = { 'location' },
}, },
tabline = {}, tabline = {},
extensions = {} extensions = {},
} }

View File

@ -4,6 +4,7 @@
local lualine = require 'lualine' local lualine = require 'lualine'
-- Color table for highlights -- Color table for highlights
-- stylua: ignore
local colors = { local colors = {
bg = '#202328', bg = '#202328',
fg = '#bbc2cf', fg = '#bbc2cf',
@ -15,32 +16,36 @@ local colors = {
violet = '#a9a1e1', violet = '#a9a1e1',
magenta = '#c678dd', magenta = '#c678dd',
blue = '#51afef', blue = '#51afef',
red = '#ec5f67' red = '#ec5f67',
} }
local conditions = { local conditions = {
buffer_not_empty = function() return vim.fn.empty(vim.fn.expand('%:t')) ~= 1 end, buffer_not_empty = function()
hide_in_width = function() return vim.fn.winwidth(0) > 80 end, return vim.fn.empty(vim.fn.expand '%:t') ~= 1
end,
hide_in_width = function()
return vim.fn.winwidth(0) > 80
end,
check_git_workspace = function() check_git_workspace = function()
local filepath = vim.fn.expand('%:p:h') local filepath = vim.fn.expand '%:p:h'
local gitdir = vim.fn.finddir('.git', filepath .. ';') local gitdir = vim.fn.finddir('.git', filepath .. ';')
return gitdir and #gitdir > 0 and #gitdir < #filepath return gitdir and #gitdir > 0 and #gitdir < #filepath
end end,
} }
-- Config -- Config
local config = { local config = {
options = { options = {
-- Disable sections and component separators -- Disable sections and component separators
component_separators = "", component_separators = '',
section_separators = "", section_separators = '',
theme = { theme = {
-- We are going to use lualine_c an lualine_x as left and -- We are going to use lualine_c an lualine_x as left and
-- right section. Both are highlighted by c theme . So we -- right section. Both are highlighted by c theme . So we
-- are just setting default looks o statusline -- are just setting default looks o statusline
normal = { c = { fg = colors.fg, bg = colors.bg } }, normal = { c = { fg = colors.fg, bg = colors.bg } },
inactive = {c = {fg = colors.fg, bg = colors.bg}} inactive = { c = { fg = colors.fg, bg = colors.bg } },
} },
}, },
sections = { sections = {
-- these are to remove the defaults -- these are to remove the defaults
@ -50,7 +55,7 @@ local config = {
lualine_z = {}, lualine_z = {},
-- These will be filled later -- These will be filled later
lualine_c = {}, lualine_c = {},
lualine_x = {} lualine_x = {},
}, },
inactive_sections = { inactive_sections = {
-- these are to remove the defaults -- these are to remove the defaults
@ -59,8 +64,8 @@ local config = {
lualine_y = {}, lualine_y = {},
lualine_z = {}, lualine_z = {},
lualine_c = {}, lualine_c = {},
lualine_x = {} lualine_x = {},
} },
} }
-- Inserts a component in lualine_c at left section -- Inserts a component in lualine_c at left section
@ -74,9 +79,11 @@ local function ins_right(component)
end end
ins_left { ins_left {
function() return '' end, function()
return ''
end,
color = { fg = colors.blue }, -- Sets highlighting of component color = { fg = colors.blue }, -- Sets highlighting of component
left_padding = 0 -- We don't need space before this left_padding = 0, -- We don't need space before this
} }
ins_left { ins_left {
@ -103,27 +110,25 @@ ins_left {
rm = colors.cyan, rm = colors.cyan,
['r?'] = colors.cyan, ['r?'] = colors.cyan,
['!'] = colors.red, ['!'] = colors.red,
t = colors.red t = colors.red,
} }
vim.api.nvim_command( vim.api.nvim_command('hi! LualineMode guifg=' .. mode_color[vim.fn.mode()] .. ' guibg=' .. colors.bg)
'hi! LualineMode guifg=' .. mode_color[vim.fn.mode()] .. " guibg=" ..
colors.bg)
return '' return ''
end, end,
color = "LualineMode", color = 'LualineMode',
left_padding = 0 left_padding = 0,
} }
ins_left { ins_left {
-- filesize component -- filesize component
'filesize', 'filesize',
condition = conditions.buffer_not_empty condition = conditions.buffer_not_empty,
} }
ins_left { ins_left {
'filename', 'filename',
condition = conditions.buffer_not_empty, condition = conditions.buffer_not_empty,
color = {fg = colors.magenta, gui = 'bold'} color = { fg = colors.magenta, gui = 'bold' },
} }
ins_left { 'location' } ins_left { 'location' }
@ -136,12 +141,16 @@ ins_left {
symbols = { error = '', warn = '', info = '' }, symbols = { error = '', warn = '', info = '' },
color_error = { fg = colors.red }, color_error = { fg = colors.red },
color_warn = { fg = colors.yellow }, color_warn = { fg = colors.yellow },
color_info = {fg = colors.cyan} color_info = { fg = colors.cyan },
} }
-- Insert mid section. You can make any number of sections in neovim :) -- Insert mid section. You can make any number of sections in neovim :)
-- for lualine it's any number greater then 2 -- for lualine it's any number greater then 2
ins_left {function() return '%=' end} ins_left {
function()
return '%='
end,
}
ins_left { ins_left {
-- Lsp server name . -- Lsp server name .
@ -149,7 +158,9 @@ ins_left {
local msg = 'No Active Lsp' local msg = 'No Active Lsp'
local buf_ft = vim.api.nvim_buf_get_option(0, 'filetype') local buf_ft = vim.api.nvim_buf_get_option(0, 'filetype')
local clients = vim.lsp.get_active_clients() local clients = vim.lsp.get_active_clients()
if next(clients) == nil then return msg end if next(clients) == nil then
return msg
end
for _, client in ipairs(clients) do for _, client in ipairs(clients) do
local filetypes = client.config.filetypes local filetypes = client.config.filetypes
if filetypes and vim.fn.index(filetypes, buf_ft) ~= -1 then if filetypes and vim.fn.index(filetypes, buf_ft) ~= -1 then
@ -159,7 +170,7 @@ ins_left {
return msg return msg
end, end,
icon = ' LSP:', icon = ' LSP:',
color = {fg = '#ffffff', gui = 'bold'} color = { fg = '#ffffff', gui = 'bold' },
} }
-- Add components to right sections -- Add components to right sections
@ -167,21 +178,21 @@ ins_right {
'o:encoding', -- option component same as &encoding in viml 'o:encoding', -- option component same as &encoding in viml
upper = true, -- I'm not sure why it's upper case either ;) upper = true, -- I'm not sure why it's upper case either ;)
condition = conditions.hide_in_width, condition = conditions.hide_in_width,
color = {fg = colors.green, gui = 'bold'} color = { fg = colors.green, gui = 'bold' },
} }
ins_right { ins_right {
'fileformat', 'fileformat',
upper = true, upper = true,
icons_enabled = false, -- I think icons are cool but Eviline doesn't have them. sigh icons_enabled = false, -- I think icons are cool but Eviline doesn't have them. sigh
color = {fg = colors.green, gui = 'bold'} color = { fg = colors.green, gui = 'bold' },
} }
ins_right { ins_right {
'branch', 'branch',
icon = '', icon = '',
condition = conditions.check_git_workspace, condition = conditions.check_git_workspace,
color = {fg = colors.violet, gui = 'bold'} color = { fg = colors.violet, gui = 'bold' },
} }
ins_right { ins_right {
@ -191,13 +202,15 @@ ins_right {
color_added = { fg = colors.green }, color_added = { fg = colors.green },
color_modified = { fg = colors.orange }, color_modified = { fg = colors.orange },
color_removed = { fg = colors.red }, color_removed = { fg = colors.red },
condition = conditions.hide_in_width condition = conditions.hide_in_width,
} }
ins_right { ins_right {
function() return '' end, function()
return ''
end,
color = { fg = colors.blue }, color = { fg = colors.blue },
right_padding = 0 right_padding = 0,
} }
-- Now don't forget to initialize lualine -- Now don't forget to initialize lualine

View File

@ -17,11 +17,15 @@ local function find_next_hl(status, str_checked)
-- Gets the next valid hl group from str_checked -- Gets the next valid hl group from str_checked
local hl_pos_start, hl_pos_end = status:find('%%#.-#', str_checked) local hl_pos_start, hl_pos_end = status:find('%%#.-#', str_checked)
while true do while true do
if not hl_pos_start then return nil end if not hl_pos_start then
return nil
end
-- When there are more that one hl group next to one another like -- When there are more that one hl group next to one another like
-- %#HL1#%#HL2#%#HL3# we need to return HL3. This makes that happen. -- %#HL1#%#HL2#%#HL3# we need to return HL3. This makes that happen.
local next_start, next_end = status:find('^%%#.-#', hl_pos_end + 1) local next_start, next_end = status:find('^%%#.-#', hl_pos_end + 1)
if next_start == nil then break end if next_start == nil then
break
end
hl_pos_start, hl_pos_end = next_start, next_end hl_pos_start, hl_pos_end = next_start, next_end
end end
return status:sub(hl_pos_start + 2, hl_pos_end - 1) return status:sub(hl_pos_start + 2, hl_pos_end - 1)
@ -31,9 +35,15 @@ end
local function fill_section_separator(status, str_checked, last_hl, sep, reverse) local function fill_section_separator(status, str_checked, last_hl, sep, reverse)
-- Inserts transitional separator along with transitional highlight -- Inserts transitional separator along with transitional highlight
local next_hl = find_next_hl(status, str_checked) local next_hl = find_next_hl(status, str_checked)
if last_hl == nil then last_hl = 'Normal' end if last_hl == nil then
if next_hl == nil then next_hl = 'Normal' end last_hl = 'Normal'
if #next_hl == 0 or #last_hl == 0 then return end end
if next_hl == nil then
next_hl = 'Normal'
end
if #next_hl == 0 or #last_hl == 0 then
return
end
local transitional_highlight = reverse -- lua ternary assignment x ? y : z local transitional_highlight = reverse -- lua ternary assignment x ? y : z
and modules.highlight.get_transitional_highlights(last_hl, next_hl) and modules.highlight.get_transitional_highlights(last_hl, next_hl)
or modules.highlight.get_transitional_highlights(next_hl, last_hl) or modules.highlight.get_transitional_highlights(next_hl, last_hl)
@ -48,12 +58,13 @@ local function apply_transitional_separators(status)
local copied_pos = 1 -- Tracks how much we've copied over to status_applied local copied_pos = 1 -- Tracks how much we've copied over to status_applied
local str_checked = 1 -- Tracks where the searcher head is at local str_checked = 1 -- Tracks where the searcher head is at
-- Process entire status replace the %s{sep} & %S{sep} placeholders -- Process entire status replace the %s{sep} & %S{sep} placeholders
-- with proper transitional separator. -- with proper transitional separator.
while str_checked ~= nil do while str_checked ~= nil do
str_checked = status:find('%%', str_checked) str_checked = status:find('%%', str_checked)
if str_checked == nil then break end if str_checked == nil then
break
end
table.insert(status_applied, status:sub(copied_pos, str_checked - 1)) table.insert(status_applied, status:sub(copied_pos, str_checked - 1))
-- -1 so we don't copy '%' -- -1 so we don't copy '%'
copied_pos = str_checked copied_pos = str_checked
@ -67,7 +78,9 @@ local function apply_transitional_separators(status)
local sep = status:match('^%%s{(.-)}', str_checked) local sep = status:match('^%%s{(.-)}', str_checked)
str_checked = str_checked + #sep + 4 -- 4 = len(%{}) str_checked = str_checked + #sep + 4 -- 4 = len(%{})
local trans_sep = fill_section_separator(status, str_checked, last_hl, sep, false) local trans_sep = fill_section_separator(status, str_checked, last_hl, sep, false)
if trans_sep then table.insert(status_applied, trans_sep) end if trans_sep then
table.insert(status_applied, trans_sep)
end
copied_pos = str_checked copied_pos = str_checked
elseif next_char == 'S' then elseif next_char == 'S' then
-- %S{sep} is marker for right separator and -- %S{sep} is marker for right separator and
@ -79,12 +92,13 @@ local function apply_transitional_separators(status)
str_checked = status:find('}', str_checked) + 1 str_checked = status:find('}', str_checked) + 1
end end
local trans_sep = fill_section_separator(status, str_checked, last_hl, sep, true) local trans_sep = fill_section_separator(status, str_checked, last_hl, sep, true)
if trans_sep then table.insert(status_applied, trans_sep) end if trans_sep then
table.insert(status_applied, trans_sep)
end
copied_pos = str_checked copied_pos = str_checked
elseif next_char == '%' then elseif next_char == '%' then
str_checked = str_checked + 2 -- Skip the following % too str_checked = str_checked + 2 -- Skip the following % too
elseif next_char == '=' and last_hl and elseif next_char == '=' and last_hl and (last_hl:find '^lualine_a' or last_hl:find '^lualine_b') then
(last_hl:find('^lualine_a') or last_hl:find('^lualine_b')) then
-- TODO: Fix this properly -- TODO: Fix this properly
-- This check for lualine_a and lualine_b is dumb. It doesn't garantee -- This check for lualine_a and lualine_b is dumb. It doesn't garantee
-- c or x section isn't present. Worst case sinario after this patch -- c or x section isn't present. Worst case sinario after this patch
@ -111,7 +125,9 @@ local function statusline(sections, is_focused)
-- insert highlight+components of this section to status_builder -- insert highlight+components of this section to status_builder
local section_data = modules.utils_section.draw_section( local section_data = modules.utils_section.draw_section(
sections['lualine_' .. section_name], sections['lualine_' .. section_name],
section_name, is_focused) section_name,
is_focused
)
if #section_data > 0 then if #section_data > 0 then
if not applied_midsection_devider and section_name > 'c' then if not applied_midsection_devider and section_name > 'c' then
applied_midsection_devider = true applied_midsection_devider = true
@ -143,13 +159,17 @@ local function get_extension_sections(current_ft, is_focused)
return nil return nil
end end
local function tabline() return statusline(config.tabline, true) end local function tabline()
return statusline(config.tabline, true)
end
local function notify_theme_error(theme_name) local function notify_theme_error(theme_name)
local message_template = theme_name ~= 'auto' and [[ local message_template = theme_name ~= 'auto'
and [[
### options.theme ### options.theme
Theme `%s` not found, falling back to `auto`. Check if spelling is right. Theme `%s` not found, falling back to `auto`. Check if spelling is right.
]] or [[ ]]
or [[
### options.theme ### options.theme
Theme `%s` failed, falling back to `gruvbox`. Theme `%s` failed, falling back to `gruvbox`.
This shouldn't happen. This shouldn't happen.
@ -164,7 +184,9 @@ local function setup_theme()
local theme_name = config.options.theme local theme_name = config.options.theme
if type(theme_name) == 'string' then if type(theme_name) == 'string' then
local ok, theme = pcall(modules.loader.load_theme, theme_name) local ok, theme = pcall(modules.loader.load_theme, theme_name)
if ok and theme then return theme end if ok and theme then
return theme
end
elseif type(theme_name) == 'table' then elseif type(theme_name) == 'table' then
-- use the provided theme as-is -- use the provided theme as-is
return config.options.theme return config.options.theme
@ -172,10 +194,12 @@ local function setup_theme()
if theme_name ~= 'auto' then if theme_name ~= 'auto' then
notify_theme_error(theme_name) notify_theme_error(theme_name)
local ok, theme = pcall(modules.loader.load_theme, 'auto') local ok, theme = pcall(modules.loader.load_theme, 'auto')
if ok and theme then return theme end if ok and theme then
return theme
end end
notify_theme_error('auto') end
return modules.loader.load_theme('gruvbox') notify_theme_error 'auto'
return modules.loader.load_theme 'gruvbox'
end end
local theme = get_theme_from_config() local theme = get_theme_from_config()
modules.highlight.create_highlight_groups(theme) modules.highlight.create_highlight_groups(theme)
@ -192,7 +216,7 @@ end
local function set_statusline() local function set_statusline()
if next(config.sections) ~= nil or next(config.inactive_sections) ~= nil then if next(config.sections) ~= nil or next(config.inactive_sections) ~= nil then
vim.cmd('autocmd lualine VimResized * redrawstatus') vim.cmd 'autocmd lualine VimResized * redrawstatus'
else else
vim.go.statusline = nil vim.go.statusline = nil
end end
@ -219,7 +243,9 @@ end
local function status_dispatch(focused) local function status_dispatch(focused)
-- disable on specific filetypes -- disable on specific filetypes
if new_config then reset_lualine() end if new_config then
reset_lualine()
end
local current_ft = vim.bo.filetype local current_ft = vim.bo.filetype
local is_focused = focused ~= nil and focused or modules.utils.is_focused() local is_focused = focused ~= nil and focused or modules.utils.is_focused()
for _, ft in pairs(config.options.disabled_filetypes) do for _, ft in pairs(config.options.disabled_filetypes) do

View File

@ -43,14 +43,17 @@ local Component = {
self.options.color_highlight = highlight.create_component_highlight_group( self.options.color_highlight = highlight.create_component_highlight_group(
self.options.color, self.options.color,
self.options.component_name, self.options.component_name,
self.options) self.options
)
end end
end, end,
-- set upper or lower case -- set upper or lower case
apply_case = function(self) apply_case = function(self)
-- Donn't work on components that emit vim statusline escaped chars -- Donn't work on components that emit vim statusline escaped chars
if self.status:find('%%') and not self.status:find('%%%%') then return end if self.status:find '%%' and not self.status:find '%%%%' then
return
end
if self.options.upper == true then if self.options.upper == true then
self.status = self.status:upper() self.status = self.status:upper()
elseif self.options.lower == true then elseif self.options.lower == true then
@ -63,27 +66,26 @@ local Component = {
local l_padding = (self.options.left_padding or self.options.padding or 1) local l_padding = (self.options.left_padding or self.options.padding or 1)
local r_padding = (self.options.right_padding or self.options.padding or 1) local r_padding = (self.options.right_padding or self.options.padding or 1)
if l_padding then if l_padding then
if self.status:find('%%#.*#') == 1 then if self.status:find '%%#.*#' == 1 then
-- When component has changed the highlight at begining -- When component has changed the highlight at begining
-- we will add the padding after the highlight -- we will add the padding after the highlight
local pre_highlight = local pre_highlight = vim.fn.matchlist(self.status, [[\(%#.\{-\}#\)]])[2]
vim.fn.matchlist(self.status, [[\(%#.\{-\}#\)]])[2] self.status = pre_highlight .. string.rep(' ', l_padding) .. self.status:sub(#pre_highlight + 1, #self.status)
self.status = pre_highlight .. string.rep(' ', l_padding) ..
self.status:sub(#pre_highlight + 1, #self.status)
else else
self.status = string.rep(' ', l_padding) .. self.status self.status = string.rep(' ', l_padding) .. self.status
end end
end end
if r_padding then self.status = self.status .. string.rep(' ', r_padding) end if r_padding then
self.status = self.status .. string.rep(' ', r_padding)
end
end, end,
-- Applies custom highlights for component -- Applies custom highlights for component
apply_highlights = function(self, default_highlight) apply_highlights = function(self, default_highlight)
if self.options.color_highlight then if self.options.color_highlight then
self.status = highlight.component_format_highlight( self.status = highlight.component_format_highlight(self.options.color_highlight) .. self.status
self.options.color_highlight) .. self.status
end end
if type(self.options.separator) ~= 'table' and self.status:find('%%#') then if type(self.options.separator) ~= 'table' and self.status:find '%%#' then
-- Apply default highlight only when we aren't applying trans sep and -- Apply default highlight only when we aren't applying trans sep and
-- the component has changed it's hl. since we won't be applying -- the component has changed it's hl. since we won't be applying
-- regular sep in those cases so ending with default hl isn't neccessay -- regular sep in those cases so ending with default hl isn't neccessay
@ -93,7 +95,9 @@ local Component = {
end end
-- Prepend default hl when the component doesn't start with hl otherwise -- Prepend default hl when the component doesn't start with hl otherwise
-- color in previous component can cause side effect -- color in previous component can cause side effect
if not self.status:find('^%%#') then self.status = default_highlight .. self.status end if not self.status:find '^%%#' then
self.status = default_highlight .. self.status
end
end, end,
-- Apply icon in front of component -- Apply icon in front of component
@ -125,22 +129,23 @@ local Component = {
end, end,
apply_section_separators = function(self) apply_section_separators = function(self)
if type(self.options.separator) ~= 'table' then return end if type(self.options.separator) ~= 'table' then
return
end
if self.options.separator[1] ~= '' then if self.options.separator[1] ~= '' then
self.status = string.format('%%s{%s}%s', self.options.separator[1], self.status = string.format('%%s{%s}%s', self.options.separator[1], self.status)
self.status)
self.strip_previous_separator = true self.strip_previous_separator = true
end end
if self.options.separator[2] ~= '' then if self.options.separator[2] ~= '' then
self.status = string.format('%s%%S{%s}', self.status, self.status = string.format('%s%%S{%s}', self.status, self.options.separator[2])
self.options.separator[2])
end end
end, end,
strip_separator = function(self) strip_separator = function(self)
if not self.applied_separator then self.applied_separator = '' end if not self.applied_separator then
self.status = self.status:sub(1, (#self.status - self.applied_separator = ''
(#self.applied_separator))) end
self.status = self.status:sub(1, (#self.status - #self.applied_separator))
self.applied_separator = nil self.applied_separator = nil
return self.status return self.status
end, end,
@ -161,7 +166,9 @@ local Component = {
return self.status return self.status
end end
local status = self:update_status(is_focused) local status = self:update_status(is_focused)
if self.options.format then status = self.options.format(status or '') end if self.options.format then
status = self.options.format(status or '')
end
if type(status) == 'string' and #status > 0 then if type(status) == 'string' and #status > 0 then
self.status = status self.status = status
self:apply_icon() self:apply_icon()
@ -172,7 +179,7 @@ local Component = {
self:apply_separator() self:apply_separator()
end end
return self.status return self.status
end end,
} }
return Component return Component

View File

@ -9,7 +9,7 @@ Branch.sep = package.config:sub(1, 1)
-- event watcher to watch head file -- event watcher to watch head file
-- Use file wstch for non windows and poll for windows. -- Use file wstch for non windows and poll for windows.
-- windows doesn't like file watch for some reason. -- windows doesn't like file watch for some reason.
Branch.file_changed = Branch.sep ~= "\\" and vim.loop.new_fs_event() or vim.loop.new_fs_poll() Branch.file_changed = Branch.sep ~= '\\' and vim.loop.new_fs_event() or vim.loop.new_fs_poll()
Branch.active_bufnr = '0' Branch.active_bufnr = '0'
local branch_cache = {} -- stores last known branch for a buffer local branch_cache = {} -- stores last known branch for a buffer
-- Initilizer -- Initilizer
@ -28,7 +28,9 @@ Branch.update_status = function(_, is_focused)
-- Sync buffer -- Sync buffer
Branch.find_git_dir() Branch.find_git_dir()
end end
if not is_focused then return branch_cache[vim.fn.bufnr()] or '' end if not is_focused then
return branch_cache[vim.fn.bufnr()] or ''
end
return Branch.git_branch return Branch.git_branch
end end
@ -36,36 +38,38 @@ local git_dir_cache = {} -- Stores git paths that we already know of
-- returns full path to git directory for current directory -- returns full path to git directory for current directory
function Branch.find_git_dir() function Branch.find_git_dir()
-- get file dir so we can search from that dir -- get file dir so we can search from that dir
local file_dir = vim.fn.expand('%:p:h') local file_dir = vim.fn.expand '%:p:h'
local root_dir = file_dir local root_dir = file_dir
local git_dir local git_dir
-- Search upward for .git file or folder -- Search upward for .git file or folder
while (root_dir) do while root_dir do
if git_dir_cache[root_dir] then if git_dir_cache[root_dir] then
git_dir = git_dir_cache[root_dir] git_dir = git_dir_cache[root_dir]
break break
end end
local git_path = root_dir .. Branch.sep .. '.git' local git_path = root_dir .. Branch.sep .. '.git'
local git_file_stat = vim.loop.fs_stat(git_path) local git_file_stat = vim.loop.fs_stat(git_path)
if (git_file_stat) then if git_file_stat then
if git_file_stat.type == 'directory' then if git_file_stat.type == 'directory' then
git_dir = git_path git_dir = git_path
elseif git_file_stat.type == 'file' then elseif git_file_stat.type == 'file' then
-- separate git-dir or submodule is used -- separate git-dir or submodule is used
local file = io.open(git_path) local file = io.open(git_path)
git_dir = file:read() git_dir = file:read()
git_dir = git_dir:match('gitdir: (.+)$') git_dir = git_dir:match 'gitdir: (.+)$'
file:close() file:close()
-- submodule / relative file path -- submodule / relative file path
if git_dir and git_dir:sub(1, 1) ~= Branch.sep and not git_dir:match('^%a:.*$') then if git_dir and git_dir:sub(1, 1) ~= Branch.sep and not git_dir:match '^%a:.*$' then
git_dir = git_path:match('(.*).git') .. git_dir git_dir = git_path:match '(.*).git' .. git_dir
end end
end end
if git_dir then if git_dir then
local head_file_stat = vim.loop.fs_stat(git_dir .. Branch.sep .. 'HEAD') local head_file_stat = vim.loop.fs_stat(git_dir .. Branch.sep .. 'HEAD')
if head_file_stat and head_file_stat.type == 'file' then if head_file_stat and head_file_stat.type == 'file' then
break break
else git_dir = nil end else
git_dir = nil
end
end end
end end
root_dir = root_dir:match('(.*)' .. Branch.sep .. '.-') root_dir = root_dir:match('(.*)' .. Branch.sep .. '.-')
@ -85,7 +89,7 @@ function Branch.get_git_head(head_file)
if f_head then if f_head then
local HEAD = f_head:read() local HEAD = f_head:read()
f_head:close() f_head:close()
local branch = HEAD:match('ref: refs/heads/(.+)$') local branch = HEAD:match 'ref: refs/heads/(.+)$'
if branch then if branch then
Branch.git_branch = branch Branch.git_branch = branch
else else
@ -103,12 +107,14 @@ function Branch.update_branch()
if git_dir and #git_dir > 0 then if git_dir and #git_dir > 0 then
local head_file = git_dir .. Branch.sep .. 'HEAD' local head_file = git_dir .. Branch.sep .. 'HEAD'
Branch.get_git_head(head_file) Branch.get_git_head(head_file)
Branch.file_changed:start(head_file, Branch.file_changed:start(
Branch.sep ~= "\\" and {} or 1000, head_file,
Branch.sep ~= '\\' and {} or 1000,
vim.schedule_wrap(function() vim.schedule_wrap(function()
-- reset file-watch -- reset file-watch
Branch.update_branch() Branch.update_branch()
end)) end)
)
else else
-- set to '' when git dir was not found -- set to '' when git dir was not found
Branch.git_branch = '' Branch.git_branch = ''

View File

@ -14,7 +14,7 @@ local default_symbols = {
error = '', -- xf659 error = '', -- xf659
warn = '', -- xf529 warn = '', -- xf529
info = '', -- xf7fc info = '', -- xf7fc
hint = '' -- xf838 hint = '', -- xf838
}, },
no_icons = { error = 'E:', warn = 'W:', info = 'I:', hint = 'H:' }, no_icons = { error = 'E:', warn = 'W:', info = 'I:', hint = 'H:' },
} }
@ -50,34 +50,42 @@ Diagnostics.new = function(self, options, child)
-- Run super() -- Run super()
local new_diagnostics = self._parent:new(options, child or Diagnostics) local new_diagnostics = self._parent:new(options, child or Diagnostics)
-- Apply default options -- Apply default options
new_diagnostics.options = new_diagnostics.options = vim.tbl_deep_extend('keep', new_diagnostics.options or {}, default_options)
vim.tbl_deep_extend('keep', new_diagnostics.options or {}, default_options)
-- Apply default symbols -- Apply default symbols
new_diagnostics.symbols = new_diagnostics.symbols = vim.tbl_extend(
vim.tbl_extend('keep', new_diagnostics.options.symbols or {}, 'keep',
new_diagnostics.options.icons_enabled ~= false new_diagnostics.options.symbols or {},
and default_symbols.icons or default_symbols.no_icons) new_diagnostics.options.icons_enabled ~= false and default_symbols.icons or default_symbols.no_icons
)
-- Initialize highlight groups -- Initialize highlight groups
if new_diagnostics.options.colored then if new_diagnostics.options.colored then
new_diagnostics.highlight_groups = { new_diagnostics.highlight_groups = {
error = modules.highlight.create_component_highlight_group( error = modules.highlight.create_component_highlight_group(
new_diagnostics.options.color_error, 'diagnostics_error', new_diagnostics.options.color_error,
new_diagnostics.options), 'diagnostics_error',
new_diagnostics.options
),
warn = modules.highlight.create_component_highlight_group( warn = modules.highlight.create_component_highlight_group(
new_diagnostics.options.color_warn, 'diagnostics_warn', new_diagnostics.options.color_warn,
new_diagnostics.options), 'diagnostics_warn',
new_diagnostics.options
),
info = modules.highlight.create_component_highlight_group( info = modules.highlight.create_component_highlight_group(
new_diagnostics.options.color_info, 'diagnostics_info', new_diagnostics.options.color_info,
new_diagnostics.options), 'diagnostics_info',
new_diagnostics.options
),
hint = modules.highlight.create_component_highlight_group( hint = modules.highlight.create_component_highlight_group(
new_diagnostics.options.color_hint, 'diagnostics_hint', new_diagnostics.options.color_hint,
new_diagnostics.options) 'diagnostics_hint',
new_diagnostics.options
),
} }
end end
-- Error out no source -- Error out no source
if new_diagnostics.options.sources == nil then if new_diagnostics.options.sources == nil then
print('no sources for diagnostics configured') print 'no sources for diagnostics configured'
return '' return ''
end end
-- Initialize variable to store last update so we can use it in insert -- Initialize variable to store last update so we can use it in insert
@ -87,8 +95,7 @@ Diagnostics.new = function(self, options, child)
end end
Diagnostics.update_status = function(self) Diagnostics.update_status = function(self)
if not self.options.update_in_insert if not self.options.update_in_insert and vim.api.nvim_get_mode().mode:sub(1, 1) == 'i' then
and vim.api.nvim_get_mode().mode:sub(1,1) == 'i' then
return self.last_update return self.last_update
end end
local error_count, warning_count, info_count, hint_count = 0, 0, 0, 0 local error_count, warning_count, info_count, hint_count = 0, 0, 0, 0
@ -104,7 +111,7 @@ Diagnostics.update_status = function(self)
error = error_count, error = error_count,
warn = warning_count, warn = warning_count,
info = info_count, info = info_count,
hint = hint_count hint = hint_count,
} }
if self.options.colored then if self.options.colored then
local colors = {} local colors = {}
@ -113,8 +120,7 @@ Diagnostics.update_status = function(self)
end end
for _, section in ipairs(self.options.sections) do for _, section in ipairs(self.options.sections) do
if data[section] ~= nil and data[section] > 0 then if data[section] ~= nil and data[section] > 0 then
table.insert(result, table.insert(result, colors[section] .. self.symbols[section] .. data[section])
colors[section] .. self.symbols[section] .. data[section])
end end
end end
else else
@ -154,20 +160,19 @@ Diagnostics.diagnostic_sources = {
else else
return 0, 0, 0, 0 return 0, 0, 0, 0
end end
end end,
} }
Diagnostics.get_diagnostics = function(sources) Diagnostics.get_diagnostics = function(sources)
local result = {} local result = {}
for index, source in ipairs(sources) do for index, source in ipairs(sources) do
if type(source) == 'string' then if type(source) == 'string' then
local error_count, warning_count, info_count, hint_count = local error_count, warning_count, info_count, hint_count = Diagnostics.diagnostic_sources[source]()
Diagnostics.diagnostic_sources[source]()
result[index] = { result[index] = {
error = error_count, error = error_count,
warn = warning_count, warn = warning_count,
info = info_count, info = info_count,
hint = hint_count hint = hint_count,
} }
elseif type(source) == 'function' then elseif type(source) == 'function' then
local source_result = source() local source_result = source()
@ -176,7 +181,7 @@ Diagnostics.get_diagnostics = function(sources)
error = source_result.error or 0, error = source_result.error or 0,
warn = source_result.warning or 0, warn = source_result.warning or 0,
info = source_result.info or 0, info = source_result.info or 0,
hint = source_result.hin or 0 hint = source_result.hin or 0,
} }
end end
end end

View File

@ -24,37 +24,38 @@ local default_options = {
colored = true, colored = true,
symbols = { added = '+', modified = '~', removed = '-' }, symbols = { added = '+', modified = '~', removed = '-' },
color_added = { color_added = {
fg = modules.utils.extract_highlight_colors('DiffAdd', 'fg') fg = modules.utils.extract_highlight_colors('DiffAdd', 'fg') or '#f0e130',
or '#f0e130',
}, },
color_modified = { color_modified = {
fg = modules.utils.extract_highlight_colors('DiffChange', 'fg') fg = modules.utils.extract_highlight_colors('DiffChange', 'fg') or '#ff0038',
or '#ff0038',
}, },
color_removed = { color_removed = {
fg = modules.utils.extract_highlight_colors('DiffDelete', 'fg') fg = modules.utils.extract_highlight_colors('DiffDelete', 'fg') or '#ff0038',
or '#ff0038',
}, },
} }
-- Initializer -- Initializer
Diff.new = function(self, options, child) Diff.new = function(self, options, child)
local new_instance = self._parent:new(options, child or Diff) local new_instance = self._parent:new(options, child or Diff)
new_instance.options = vim.tbl_deep_extend('keep', new_instance.options = vim.tbl_deep_extend('keep', new_instance.options or {}, default_options)
new_instance.options or {},
default_options)
-- create highlights and save highlight_name in highlights table -- create highlights and save highlight_name in highlights table
if new_instance.options.colored then if new_instance.options.colored then
new_instance.highlights = { new_instance.highlights = {
added = modules.highlight.create_component_highlight_group( added = modules.highlight.create_component_highlight_group(
new_instance.options.color_added, 'diff_added', new_instance.options.color_added,
new_instance.options), 'diff_added',
new_instance.options
),
modified = modules.highlight.create_component_highlight_group( modified = modules.highlight.create_component_highlight_group(
new_instance.options.color_modified, 'diff_modified', new_instance.options.color_modified,
new_instance.options), 'diff_modified',
new_instance.options
),
removed = modules.highlight.create_component_highlight_group( removed = modules.highlight.create_component_highlight_group(
new_instance.options.color_removed, 'diff_removed', new_instance.options.color_removed,
new_instance.options) 'diff_removed',
new_instance.options
),
} }
end end
@ -82,8 +83,12 @@ Diff.update_status = function(self, is_focused)
git_diff = self.options.source() git_diff = self.options.source()
end end
if not is_focused then git_diff = diff_cache[vim.fn.bufnr()] or {} end if not is_focused then
if git_diff == nil then return '' end git_diff = diff_cache[vim.fn.bufnr()] or {}
end
if git_diff == nil then
return ''
end
local colors = {} local colors = {}
if self.options.colored then if self.options.colored then
@ -98,8 +103,7 @@ Diff.update_status = function(self, is_focused)
for _, name in ipairs { 'added', 'modified', 'removed' } do for _, name in ipairs { 'added', 'modified', 'removed' } do
if git_diff[name] and git_diff[name] > 0 then if git_diff[name] and git_diff[name] > 0 then
if self.options.colored then if self.options.colored then
table.insert(result, colors[name] .. self.options.symbols[name] .. table.insert(result, colors[name] .. self.options.symbols[name] .. git_diff[name])
git_diff[name])
else else
table.insert(result, self.options.symbols[name] .. git_diff[name]) table.insert(result, self.options.symbols[name] .. git_diff[name])
end end
@ -121,7 +125,9 @@ end
-- } -- }
-- error_code = { added = -1, modified = -1, removed = -1 } -- error_code = { added = -1, modified = -1, removed = -1 }
function Diff.get_sign_count() function Diff.get_sign_count()
if Diff.diff_checker_enabled then Diff.update_diff_args() end if Diff.diff_checker_enabled then
Diff.update_diff_args()
end
return Diff.git_diff or { added = -1, modified = -1, removed = -1 } return Diff.git_diff or { added = -1, modified = -1, removed = -1 }
end end
@ -131,11 +137,10 @@ function Diff.process_diff(data)
local added, removed, modified = 0, 0, 0 local added, removed, modified = 0, 0, 0
for _, line in ipairs(data) do for _, line in ipairs(data) do
if string.find(line, [[^@@ ]]) then if string.find(line, [[^@@ ]]) then
local tokens = vim.fn.matchlist(line, local tokens = vim.fn.matchlist(line, [[^@@ -\v(\d+),?(\d*) \+(\d+),?(\d*)]])
[[^@@ -\v(\d+),?(\d*) \+(\d+),?(\d*)]])
local line_stats = { local line_stats = {
mod_count = tokens[3] == '' and 1 or tonumber(tokens[3]), mod_count = tokens[3] == '' and 1 or tonumber(tokens[3]),
new_count = tokens[5] == '' and 1 or tonumber(tokens[5]) new_count = tokens[5] == '' and 1 or tonumber(tokens[5]),
} }
if line_stats.mod_count == 0 and line_stats.new_count > 0 then if line_stats.mod_count == 0 and line_stats.new_count > 0 then
@ -157,15 +162,17 @@ end
function Diff.update_diff_args() function Diff.update_diff_args()
-- Donn't show git diff when current buffer doesn't have a filename -- Donn't show git diff when current buffer doesn't have a filename
Diff.active_bufnr = tostring(vim.fn.bufnr()) Diff.active_bufnr = tostring(vim.fn.bufnr())
if #vim.fn.expand('%') == 0 then if #vim.fn.expand '%' == 0 then
Diff.diff_args = nil; Diff.diff_args = nil
Diff.git_diff = nil; Diff.git_diff = nil
return return
end end
Diff.diff_args = { Diff.diff_args = {
cmd = string.format( cmd = string.format(
[[git -C %s --no-pager diff --no-color --no-ext-diff -U0 -- %s]], [[git -C %s --no-pager diff --no-color --no-ext-diff -U0 -- %s]],
vim.fn.expand('%:h'), vim.fn.expand('%:t')), vim.fn.expand '%:h',
vim.fn.expand '%:t'
),
on_stdout = function(_, data) on_stdout = function(_, data)
if next(data) then if next(data) then
Diff.diff_output_cache = vim.list_extend(Diff.diff_output_cache, data) Diff.diff_output_cache = vim.list_extend(Diff.diff_output_cache, data)
@ -185,7 +192,7 @@ function Diff.update_diff_args()
Diff.git_diff = { added = 0, modified = 0, removed = 0 } Diff.git_diff = { added = 0, modified = 0, removed = 0 }
end end
diff_cache[vim.fn.bufnr()] = Diff.git_diff diff_cache[vim.fn.bufnr()] = Diff.git_diff
end end,
} }
Diff.update_git_diff() Diff.update_git_diff()
end end
@ -194,9 +201,13 @@ end
function Diff.update_git_diff() function Diff.update_git_diff()
if Diff.diff_args then if Diff.diff_args then
Diff.diff_output_cache = {} Diff.diff_output_cache = {}
if Diff.diff_job then Diff.diff_job:stop() end if Diff.diff_job then
Diff.diff_job:stop()
end
Diff.diff_job = modules.Job(Diff.diff_args) Diff.diff_job = modules.Job(Diff.diff_args)
if Diff.diff_job then Diff.diff_job:start() end if Diff.diff_job then
Diff.diff_job:start()
end
end end
end end

View File

@ -2,6 +2,8 @@
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local Encoding = require('lualine.component'):new() local Encoding = require('lualine.component'):new()
Encoding.update_status = function() return [[%{strlen(&fenc)?&fenc:&enc}]] end Encoding.update_status = function()
return [[%{strlen(&fenc)?&fenc:&enc}]]
end
return Encoding return Encoding

View File

@ -15,15 +15,12 @@ end
local function shorten_path(path, sep) local function shorten_path(path, sep)
-- ('([^/])[^/]+%/', '%1/', 1) -- ('([^/])[^/]+%/', '%1/', 1)
return path:gsub( return path:gsub(string.format('([^%s])[^%s]+%%%s', sep, sep, sep), '%1' .. sep, 1)
string.format('([^%s])[^%s]+%%%s', sep, sep, sep), '%1' .. sep, 1)
end end
FileName.new = function(self, options, child) FileName.new = function(self, options, child)
local new_instance = self._parent:new(options, child or FileName) local new_instance = self._parent:new(options, child or FileName)
new_instance.options = vim.tbl_deep_extend('keep', new_instance.options = vim.tbl_deep_extend('keep', new_instance.options or {}, default_options)
new_instance.options or {},
default_options)
return new_instance return new_instance
end end
@ -31,16 +28,18 @@ FileName.update_status = function(self)
local data local data
if self.options.path == 1 then if self.options.path == 1 then
-- relative path -- relative path
data = vim.fn.expand('%:~:.') data = vim.fn.expand '%:~:.'
elseif self.options.path == 2 then elseif self.options.path == 2 then
-- absolute path -- absolute path
data = vim.fn.expand('%:p') data = vim.fn.expand '%:p'
else else
-- just filename -- just filename
data = vim.fn.expand('%:t') data = vim.fn.expand '%:t'
end end
if data == '' then data = '[No Name]' end if data == '' then
data = '[No Name]'
end
if self.options.shorting_target ~= 0 then if self.options.shorting_target ~= 0 then
local windwidth = vim.fn.winwidth(0) local windwidth = vim.fn.winwidth(0)

View File

@ -3,11 +3,15 @@
local M = require('lualine.component'):new() local M = require('lualine.component'):new()
M.update_status = function() M.update_status = function()
local file = vim.fn.expand('%:p') local file = vim.fn.expand '%:p'
if file == nil or #file == 0 then return '' end if file == nil or #file == 0 then
return ''
end
local size = vim.fn.getfsize(file) local size = vim.fn.getfsize(file)
if size <= 0 then return '' end if size <= 0 then
return ''
end
local sufixes = { 'b', 'k', 'm', 'g' } local sufixes = { 'b', 'k', 'm', 'g' }

View File

@ -14,47 +14,50 @@ local default_options = {
function FileType:new(options, child) function FileType:new(options, child)
local new_instance = self._parent:new(options, child or FileType) local new_instance = self._parent:new(options, child or FileType)
new_instance.options = vim.tbl_deep_extend('keep', new_instance.options = vim.tbl_deep_extend('keep', new_instance.options or {}, default_options)
new_instance.options or {},
default_options)
return new_instance return new_instance
end end
function FileType.update_status() return vim.bo.filetype or '' end function FileType.update_status()
return vim.bo.filetype or ''
end
function FileType:apply_icon() function FileType:apply_icon()
if not self.options.icons_enabled then return end if not self.options.icons_enabled then
return
end
local icon, icon_highlight_group local icon, icon_highlight_group
local ok, devicons = pcall(require, 'nvim-web-devicons') local ok, devicons = pcall(require, 'nvim-web-devicons')
if ok then if ok then
local f_name, f_extension = vim.fn.expand('%:t'), vim.fn.expand('%:e') local f_name, f_extension = vim.fn.expand '%:t', vim.fn.expand '%:e'
icon, icon_highlight_group = devicons.get_icon(f_name, f_extension) icon, icon_highlight_group = devicons.get_icon(f_name, f_extension)
if icon and self.options.colored then if icon and self.options.colored then
local highlight_color = modules.utils.extract_highlight_colors( local highlight_color = modules.utils.extract_highlight_colors(icon_highlight_group, 'fg')
icon_highlight_group, 'fg')
local is_focused = modules.utils.is_focused() local is_focused = modules.utils.is_focused()
local default_highlight = modules.highlight.format_highlight(is_focused, local default_highlight = modules.highlight.format_highlight(is_focused, self.options.self.section)
self.options.self local icon_highlight = self.options.self.section .. '_' .. icon_highlight_group
.section)
local icon_highlight = self.options.self.section .. '_' ..
icon_highlight_group
if not modules.highlight.highlight_exists(icon_highlight .. '_normal') then if not modules.highlight.highlight_exists(icon_highlight .. '_normal') then
icon_highlight = modules.highlight.create_component_highlight_group( icon_highlight = modules.highlight.create_component_highlight_group(
{fg = highlight_color}, icon_highlight_group, { fg = highlight_color },
self.options) icon_highlight_group,
self.options
)
end end
icon = modules.highlight.component_format_highlight(icon_highlight) .. icon .. icon = modules.highlight.component_format_highlight(icon_highlight) .. icon .. default_highlight
default_highlight
end end
else else
ok = vim.fn.exists('*WebDevIconsGetFileTypeSymbol') ok = vim.fn.exists '*WebDevIconsGetFileTypeSymbol'
if ok ~= 0 then icon = vim.fn.WebDevIconsGetFileTypeSymbol() end if ok ~= 0 then
icon = vim.fn.WebDevIconsGetFileTypeSymbol()
end
end end
if not icon then return end if not icon then
return
end
if self.options.disable_text then if self.options.disable_text then
self.status = icon self.status = icon

View File

@ -2,6 +2,8 @@
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local Location = require('lualine.component'):new() local Location = require('lualine.component'):new()
Location.update_status = function() return [[%3l:%-2c]] end Location.update_status = function()
return [[%3l:%-2c]]
end
return Location return Location

View File

@ -1,6 +1,6 @@
-- Copyright (c) 2020-2021 hoob3rt -- Copyright (c) 2020-2021 hoob3rt
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local require = require'lualine_require'.require local require = require('lualine_require').require
local Mode = require('lualine.component'):new() local Mode = require('lualine.component'):new()
local get_mode = require('lualine.utils.mode').get_mode local get_mode = require('lualine.utils.mode').get_mode

View File

@ -2,6 +2,8 @@
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local Progress = require('lualine.component'):new() local Progress = require('lualine.component'):new()
Progress.update_status = function() return [[%3P]] end Progress.update_status = function()
return [[%3P]]
end
return Progress return Progress

View File

@ -5,11 +5,15 @@ EvalFuncComponent.update_status = function(self)
local ok, status local ok, status
if self.options.type == nil then if self.options.type == nil then
ok, status = pcall(EvalFuncComponent.lua_eval, component) ok, status = pcall(EvalFuncComponent.lua_eval, component)
if not ok then status = EvalFuncComponent.vim_function(component) end if not ok then
status = EvalFuncComponent.vim_function(component)
end
else else
if self.options.type == 'luae' then if self.options.type == 'luae' then
ok, status = pcall(EvalFuncComponent.lua_eval, component) ok, status = pcall(EvalFuncComponent.lua_eval, component)
if not ok then status = nil end if not ok then
status = nil
end
elseif self.options.type == 'vimf' then elseif self.options.type == 'vimf' then
status = EvalFuncComponent.vim_function(component) status = EvalFuncComponent.vim_function(component)
end end
@ -26,7 +30,9 @@ end
EvalFuncComponent.vim_function = function(name) EvalFuncComponent.vim_function = function(name)
-- vim function component -- vim function component
local ok, return_val = pcall(vim.api.nvim_call_function, name, {}) local ok, return_val = pcall(vim.api.nvim_call_function, name, {})
if not ok then return '' end -- function call failed if not ok then
return ''
end -- function call failed
ok, return_val = pcall(tostring, return_val) ok, return_val = pcall(tostring, return_val)
return ok and return_val or '' return ok and return_val or ''
end end

View File

@ -4,10 +4,14 @@ FunctionComponent.update_status = function(self, is_focused)
-- 1st element in options table is the function provided by config -- 1st element in options table is the function provided by config
local ok, retval local ok, retval
ok, retval = pcall(self.options[1], self, is_focused) ok, retval = pcall(self.options[1], self, is_focused)
if not ok then return '' end if not ok then
return ''
end
if type(retval) ~= 'string' then if type(retval) ~= 'string' then
ok, retval = pcall(tostring, retval) ok, retval = pcall(tostring, retval)
if not ok then return '' end if not ok then
return ''
end
end end
return retval return retval
end end

View File

@ -4,20 +4,26 @@ VarComponent.update_status = function(self)
-- vim veriable component -- vim veriable component
-- accepts g:, v:, t:, w:, b:, o, go:, vo:, to:, wo:, bo: -- accepts g:, v:, t:, w:, b:, o, go:, vo:, to:, wo:, bo:
-- filters g portion from g:var -- filters g portion from g:var
local scope = component:match('[gvtwb]?o?') local scope = component:match '[gvtwb]?o?'
-- filters var portion from g:var -- filters var portion from g:var
local var_name = component:sub(#scope + 2, #component) local var_name = component:sub(#scope + 2, #component)
-- Displays nothing when veriable aren't present -- Displays nothing when veriable aren't present
if not (scope and var_name) then return '' end if not (scope and var_name) then
return ''
end
-- Support accessing keys within dictionary -- Support accessing keys within dictionary
-- https://github.com/shadmansaleh/lualine.nvim/issues/25#issuecomment-907374548 -- https://github.com/shadmansaleh/lualine.nvim/issues/25#issuecomment-907374548
local name_chunks = vim.split(var_name, '%.') local name_chunks = vim.split(var_name, '%.')
local return_val = vim[scope][name_chunks[1]] local return_val = vim[scope][name_chunks[1]]
for i = 2, #name_chunks do for i = 2, #name_chunks do
if return_val == nil then break end if return_val == nil then
break
end
return_val = return_val[name_chunks[i]] return_val = return_val[name_chunks[i]]
end end
if return_val == nil then return '' end if return_val == nil then
return ''
end
local ok local ok
ok, return_val = pcall(tostring, return_val) ok, return_val = pcall(tostring, return_val)
return ok and return_val or '' return ok and return_val or ''

View File

@ -6,16 +6,15 @@ local config = {
theme = 'auto', theme = 'auto',
component_separators = { '', '' }, component_separators = { '', '' },
section_separators = { '', '' }, section_separators = { '', '' },
disabled_filetypes = {} disabled_filetypes = {},
}, },
sections = { sections = {
lualine_a = { 'mode' }, lualine_a = { 'mode' },
lualine_b = {'branch', 'diff', lualine_b = { 'branch', 'diff', { 'diagnostics', sources = { 'nvim_lsp', 'coc' } } },
{'diagnostics', sources={'nvim_lsp', 'coc'}}},
lualine_c = { 'filename' }, lualine_c = { 'filename' },
lualine_x = { 'encoding', 'fileformat', 'filetype' }, lualine_x = { 'encoding', 'fileformat', 'filetype' },
lualine_y = { 'progress' }, lualine_y = { 'progress' },
lualine_z = {'location'} lualine_z = { 'location' },
}, },
inactive_sections = { inactive_sections = {
lualine_a = {}, lualine_a = {},
@ -23,10 +22,10 @@ local config = {
lualine_c = { 'filename' }, lualine_c = { 'filename' },
lualine_x = { 'location' }, lualine_x = { 'location' },
lualine_y = {}, lualine_y = {},
lualine_z = {} lualine_z = {},
}, },
tabline = {}, tabline = {},
extensions = {} extensions = {},
} }
-- change separator format 'x' or {'x'} to {'x', 'x'} -- change separator format 'x' or {'x'} to {'x', 'x'}
@ -42,24 +41,26 @@ local function fix_separators(separators)
end end
local function apply_configuration(config_table) local function apply_configuration(config_table)
if not config_table then return vim.deepcopy(config) end if not config_table then
return vim.deepcopy(config)
end
local function parse_sections(section_group_name) local function parse_sections(section_group_name)
if not config_table[section_group_name] then return end if not config_table[section_group_name] then
return
end
for section_name, section in pairs(config_table[section_group_name]) do for section_name, section in pairs(config_table[section_group_name]) do
config[section_group_name][section_name] = vim.deepcopy(section) config[section_group_name][section_name] = vim.deepcopy(section)
end end
end end
parse_sections('options') parse_sections 'options'
parse_sections('sections') parse_sections 'sections'
parse_sections('inactive_sections') parse_sections 'inactive_sections'
parse_sections('tabline') parse_sections 'tabline'
if config_table.extensions then if config_table.extensions then
config.extensions = vim.deepcopy(config_table.extensions) config.extensions = vim.deepcopy(config_table.extensions)
end end
config.options.section_separators = fix_separators( config.options.section_separators = fix_separators(config.options.section_separators)
config.options.section_separators) config.options.component_separators = fix_separators(config.options.component_separators)
config.options.component_separators = fix_separators(
config.options.component_separators)
return vim.deepcopy(config) return vim.deepcopy(config)
end end
@ -69,5 +70,5 @@ end
return { return {
get_config = get_current_config, get_config = get_current_config,
apply_configuration = apply_configuration apply_configuration = apply_configuration,
} }

View File

@ -1,6 +1,6 @@
-- Copyright (c) 2020-2021 hoob3rt -- Copyright (c) 2020-2021 hoob3rt
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local nerdtree = require('lualine.extensions.nerdtree') local nerdtree = require 'lualine.extensions.nerdtree'
local M = {} local M = {}

View File

@ -6,13 +6,18 @@ local function fugitive_branch()
local icon = '' -- e0a0 local icon = '' -- e0a0
return icon .. ' ' .. vim.fn.FugitiveHead() return icon .. ' ' .. vim.fn.FugitiveHead()
end end
local empty = {function() return ' ' end, left_padding=0, right_padding=0} local empty = {
function()
return ' '
end,
left_padding = 0,
right_padding = 0,
}
M.sections = { M.sections = {
lualine_a = { fugitive_branch }, lualine_a = { fugitive_branch },
lualine_c = { empty }, lualine_c = { empty },
lualine_z = {'location'} lualine_z = { 'location' },
} }
M.filetypes = { 'fugitive' } M.filetypes = { 'fugitive' }

View File

@ -1,13 +1,21 @@
-- Copyright (c) 2020-2021 hoob3rt -- Copyright (c) 2020-2021 hoob3rt
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local function fzf_statusline() return 'FZF' end local function fzf_statusline()
local empty = {function() return ' ' end, left_padding=0, right_padding=0} return 'FZF'
end
local empty = {
function()
return ' '
end,
left_padding = 0,
right_padding = 0,
}
local M = {} local M = {}
M.sections = { M.sections = {
lualine_a = { fzf_statusline }, lualine_a = { fzf_statusline },
lualine_c = {empty} lualine_c = { empty },
} }
M.filetypes = { 'fzf' } M.filetypes = { 'fzf' }

View File

@ -1,13 +1,21 @@
-- Copyright (c) 2020-2021 hoob3rt -- Copyright (c) 2020-2021 hoob3rt
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local function get_short_cwd() return vim.fn.fnamemodify(vim.fn.getcwd(), ':~') end local function get_short_cwd()
local empty = {function() return ' ' end, left_padding=0, right_padding=0} return vim.fn.fnamemodify(vim.fn.getcwd(), ':~')
end
local empty = {
function()
return ' '
end,
left_padding = 0,
right_padding = 0,
}
local M = {} local M = {}
M.sections = { M.sections = {
lualine_a = { get_short_cwd }, lualine_a = { get_short_cwd },
lualine_c = {empty} lualine_c = { empty },
} }
M.filetypes = { 'nerdtree' } M.filetypes = { 'nerdtree' }

View File

@ -1,6 +1,6 @@
-- Copyright (c) 2020-2021 hoob3rt -- Copyright (c) 2020-2021 hoob3rt
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local nerdtree = require('lualine.extensions.nerdtree') local nerdtree = require 'lualine.extensions.nerdtree'
local M = {} local M = {}

View File

@ -15,7 +15,13 @@ local function title()
end end
return vim.fn.getqflist({ title = 0 }).title return vim.fn.getqflist({ title = 0 }).title
end end
local empty = {function() return ' ' end, left_padding=0, right_padding=0} local empty = {
function()
return ' '
end,
left_padding = 0,
right_padding = 0,
}
local M = {} local M = {}
@ -28,7 +34,7 @@ M.sections = {
lualine_a = { label }, lualine_a = { label },
lualine_b = { title }, lualine_b = { title },
lualine_c = { empty }, lualine_c = { empty },
lualine_z = {'location'} lualine_z = { 'location' },
} }
M.filetypes = { 'qf' } M.filetypes = { 'qf' }

View File

@ -1,14 +1,22 @@
-- Copyright (c) 2020-2021 hoob3rt -- Copyright (c) 2020-2021 hoob3rt
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local function toggleterm_statusline() return 'ToggleTerm #' .. vim.b.toggle_number end local function toggleterm_statusline()
local empty = {function() return ' ' end, left_padding=0, right_padding=0} return 'ToggleTerm #' .. vim.b.toggle_number
end
local empty = {
function()
return ' '
end,
left_padding = 0,
right_padding = 0,
}
local M = {} local M = {}
M.sections = { M.sections = {
lualine_a = { toggleterm_statusline }, lualine_a = { toggleterm_statusline },
lualine_c = {empty} lualine_c = { empty },
} }
M.filetypes = { 'toggleterm' } M.filetypes = { 'toggleterm' }

View File

@ -30,7 +30,9 @@ end
local function sanitize_color(color) local function sanitize_color(color)
if type(color) == 'string' then if type(color) == 'string' then
if color:sub(1,1) == '#' then return color end -- RGB value if color:sub(1, 1) == '#' then
return color
end -- RGB value
return modules.color_utils.color_name2rgb(color) return modules.color_utils.color_name2rgb(color)
elseif type(color) == 'number' then elseif type(color) == 'number' then
if color > 255 then if color > 255 then
@ -51,15 +53,13 @@ function M.highlight(name, foreground, background, gui, link)
if foreground and foreground ~= 'none' then if foreground and foreground ~= 'none' then
table.insert(command, 'guifg=' .. foreground) table.insert(command, 'guifg=' .. foreground)
if create_cterm_colors then if create_cterm_colors then
table.insert(command, table.insert(command, 'ctermfg=' .. modules.color_utils.rgb2cterm(foreground))
'ctermfg=' .. modules.color_utils.rgb2cterm(foreground))
end end
end end
if background and background ~= 'none' then if background and background ~= 'none' then
table.insert(command, 'guibg=' .. background) table.insert(command, 'guibg=' .. background)
if create_cterm_colors then if create_cterm_colors then
table.insert(command, table.insert(command, 'ctermbg=' .. modules.color_utils.rgb2cterm(background))
'ctermbg=' .. modules.color_utils.rgb2cterm(background))
end end
end end
if gui then if gui then
@ -79,11 +79,9 @@ function M.create_highlight_groups(theme)
for section, color in pairs(sections) do for section, color in pairs(sections) do
local highlight_group_name = { 'lualine', section, mode } local highlight_group_name = { 'lualine', section, mode }
if type(color) == 'string' then -- link to a highlight group if type(color) == 'string' then -- link to a highlight group
M.highlight(table.concat(highlight_group_name, '_'), nil, M.highlight(table.concat(highlight_group_name, '_'), nil, nil, nil, color)
nil, nil, color)
else -- Define a new highlight else -- Define a new highlight
M.highlight(table.concat(highlight_group_name, '_'), color.fg, M.highlight(table.concat(highlight_group_name, '_'), color.fg, color.bg, color.gui, nil)
color.bg, color.gui, nil)
end end
end end
end end
@ -94,15 +92,20 @@ end
-- @return: (string) highlight group name with mode -- @return: (string) highlight group name with mode
local function append_mode(highlight_group) local function append_mode(highlight_group)
local mode = require('lualine.utils.mode').get_mode() local mode = require('lualine.utils.mode').get_mode()
if mode == 'VISUAL' or mode == 'V-BLOCK' or mode == 'V-LINE' or mode == if
'SELECT' or mode == 'S-LINE' or mode == 'S-BLOCK' then mode == 'VISUAL'
or mode == 'V-BLOCK'
or mode == 'V-LINE'
or mode == 'SELECT'
or mode == 'S-LINE'
or mode == 'S-BLOCK'
then
highlight_group = highlight_group .. '_visual' highlight_group = highlight_group .. '_visual'
elseif mode == 'REPLACE' or mode == 'V-REPLACE' then elseif mode == 'REPLACE' or mode == 'V-REPLACE' then
highlight_group = highlight_group .. '_replace' highlight_group = highlight_group .. '_replace'
elseif mode == 'INSERT' then elseif mode == 'INSERT' then
highlight_group = highlight_group .. '_insert' highlight_group = highlight_group .. '_insert'
elseif mode == 'COMMAND' or mode == 'EX' or mode == 'MORE' or mode == elseif mode == 'COMMAND' or mode == 'EX' or mode == 'MORE' or mode == 'CONFIRM' then
'CONFIRM' then
highlight_group = highlight_group .. '_command' highlight_group = highlight_group .. '_command'
elseif mode == 'TERMINAL' then elseif mode == 'TERMINAL' then
highlight_group = highlight_group .. '_terminal' highlight_group = highlight_group .. '_terminal'
@ -120,7 +123,9 @@ end
-- @param default_color Colors et in theme this is 2nd fall back -- @param default_color Colors et in theme this is 2nd fall back
-- @param kind (fg/bg)) -- @param kind (fg/bg))
local function get_default_component_color(color, options_color, default_color, kind) local function get_default_component_color(color, options_color, default_color, kind)
if color[kind] then return color[kind] end if color[kind] then
return color[kind]
end
if options_color then if options_color then
if type(options_color) == 'table' and options_color[kind] then if type(options_color) == 'table' and options_color[kind] then
return options_color[kind] return options_color[kind]
@ -146,54 +151,57 @@ end
-- to retrive highlight group -- to retrive highlight group
function M.create_component_highlight_group(color, highlight_tag, options) function M.create_component_highlight_group(color, highlight_tag, options)
local tag_id = 0 local tag_id = 0
while (M.highlight_exists(table.concat( while
{'lualine', highlight_tag, 'no_mode'}, '_')) M.highlight_exists(table.concat({ 'lualine', highlight_tag, 'no_mode' }, '_'))
or (options.self.section and M.highlight_exists(table.concat( or (
{options.self.section, highlight_tag, 'normal'}, '_'))) options.self.section
) do and M.highlight_exists(table.concat({ options.self.section, highlight_tag, 'normal' }, '_'))
)
do
highlight_tag = highlight_tag .. '_' .. tostring(tag_id) highlight_tag = highlight_tag .. '_' .. tostring(tag_id)
tag_id = tag_id + 1 tag_id = tag_id + 1
end end
if type(color) == 'string' then if type(color) == 'string' then
local highlight_group_name = table.concat( local highlight_group_name = table.concat({ 'lualine', highlight_tag, 'no_mode' }, '_')
{'lualine', highlight_tag, 'no_mode'}, '_')
M.highlight(highlight_group_name, nil, nil, nil, color) -- l8nk to group M.highlight(highlight_group_name, nil, nil, nil, color) -- l8nk to group
return highlight_group_name return highlight_group_name
end end
if color.bg and color.fg then if color.bg and color.fg then
-- When bg and fg are both present we donn't need to set highlighs for -- When bg and fg are both present we donn't need to set highlighs for
-- each mode as they will surely look the same. So we can work without options -- each mode as they will surely look the same. So we can work without options
local highlight_group_name = table.concat( local highlight_group_name = table.concat({ 'lualine', highlight_tag, 'no_mode' }, '_')
{'lualine', highlight_tag, 'no_mode'}, '_')
M.highlight(highlight_group_name, color.fg, color.bg, color.gui, nil) M.highlight(highlight_group_name, color.fg, color.bg, color.gui, nil)
return highlight_group_name return highlight_group_name
end end
local modes = { local modes = {
'normal', 'insert', 'visual', 'replace', 'command', 'terminal', 'inactive' 'normal',
'insert',
'visual',
'replace',
'command',
'terminal',
'inactive',
} }
local normal_hl local normal_hl
-- convert lualine_a -> a before setting section -- convert lualine_a -> a before setting section
local section = options.self.section:match('lualine_(.*)') local section = options.self.section:match 'lualine_(.*)'
if section > 'c' and not active_theme.normal[section] then if section > 'c' and not active_theme.normal[section] then
section = section_highlight_map[section] end section = section_highlight_map[section]
end
for _, mode in ipairs(modes) do for _, mode in ipairs(modes) do
local highlight_group_name = { options.self.section, highlight_tag, mode } local highlight_group_name = { options.self.section, highlight_tag, mode }
local default_color_table = active_theme[mode] and local default_color_table = active_theme[mode] and active_theme[mode][section] or active_theme.normal[section]
active_theme[mode][section] or
active_theme.normal[section]
local bg = get_default_component_color(color, options.color, default_color_table, 'bg') local bg = get_default_component_color(color, options.color, default_color_table, 'bg')
local fg = get_default_component_color(color, options.color, default_color_table, 'fg') local fg = get_default_component_color(color, options.color, default_color_table, 'fg')
-- Check if it's same as normal mode if it is no need to create aditional highlight -- Check if it's same as normal mode if it is no need to create aditional highlight
if mode ~= 'normal' then if mode ~= 'normal' then
if bg ~= normal_hl.bg or fg ~= normal_hl.fg then if bg ~= normal_hl.bg or fg ~= normal_hl.fg then
M.highlight(table.concat(highlight_group_name, '_'), fg, bg, color.gui, M.highlight(table.concat(highlight_group_name, '_'), fg, bg, color.gui, nil)
nil)
end end
else else
normal_hl = { bg = bg, fg = fg } normal_hl = { bg = bg, fg = fg }
M.highlight(table.concat(highlight_group_name, '_'), fg, bg, color.gui, M.highlight(table.concat(highlight_group_name, '_'), fg, bg, color.gui, nil)
nil)
end end
end end
return options.self.section .. '_' .. highlight_tag return options.self.section .. '_' .. highlight_tag
@ -206,7 +214,7 @@ end
-- @return: (string) formated highlight group name -- @return: (string) formated highlight group name
function M.component_format_highlight(highlight_name) function M.component_format_highlight(highlight_name)
local highlight_group = highlight_name local highlight_group = highlight_name
if highlight_name:find('no_mode') == #highlight_name - #'no_mode' + 1 then if highlight_name:find 'no_mode' == #highlight_name - #'no_mode' + 1 then
return '%#' .. highlight_group .. '#' return '%#' .. highlight_group .. '#'
end end
if modules.utils.is_focused() then if modules.utils.is_focused() then
@ -222,11 +230,8 @@ function M.component_format_highlight(highlight_name)
end end
function M.format_highlight(is_focused, highlight_group) function M.format_highlight(is_focused, highlight_group)
if highlight_group > 'lualine_c' if highlight_group > 'lualine_c' and not M.highlight_exists(highlight_group .. '_normal') then
and not M.highlight_exists(highlight_group .. '_normal') then highlight_group = 'lualine_' .. section_highlight_map[highlight_group:match 'lualine_(.)']
highlight_group = 'lualine_' ..
section_highlight_map[highlight_group:match(
'lualine_(.)')]
end end
local highlight_name local highlight_name
if not is_focused then if not is_focused then
@ -248,7 +253,9 @@ end
function M.get_transitional_highlights(left_hl, right_hl) function M.get_transitional_highlights(left_hl, right_hl)
-- When both left and right highlights are same or one is absent -- When both left and right highlights are same or one is absent
-- nothing to transition to. -- nothing to transition to.
if left_hl == nil or right_hl == nil or left_hl == right_hl then return nil end if left_hl == nil or right_hl == nil or left_hl == right_hl then
return nil
end
-- construct the name of hightlight group -- construct the name of hightlight group
local highlight_name = table.concat({ 'lualine_transitional', left_hl, 'to', right_hl }, '_') local highlight_name = table.concat({ 'lualine_transitional', left_hl, 'to', right_hl }, '_')
@ -257,8 +264,12 @@ function M.get_transitional_highlights(left_hl, right_hl)
-- Get colors from highlights -- Get colors from highlights
local fg = modules.utils.extract_highlight_colors(left_hl, 'bg') local fg = modules.utils.extract_highlight_colors(left_hl, 'bg')
local bg = modules.utils.extract_highlight_colors(right_hl, 'bg') local bg = modules.utils.extract_highlight_colors(right_hl, 'bg')
if not fg or not bg then return nil end -- Color retrieval failed if not fg or not bg then
if bg == fg then return nil end -- Separator won't be visible anyway return nil
end -- Color retrieval failed
if bg == fg then
return nil
end -- Separator won't be visible anyway
M.highlight(highlight_name, fg, bg, nil) M.highlight(highlight_name, fg, bg, nil)
end end
return '%#' .. highlight_name .. '#' return '%#' .. highlight_name .. '#'

View File

@ -25,7 +25,7 @@ return {
normal = { normal = {
a = { fg = colors.white, bg = colors.blue, gui = 'bold' }, a = { fg = colors.white, bg = colors.blue, gui = 'bold' },
b = { fg = colors.white, bg = colors.gray }, b = { fg = colors.white, bg = colors.gray },
c = {fg = colors.silver, bg = colors.black} c = { fg = colors.silver, bg = colors.black },
}, },
insert = { a = { fg = colors.white, bg = colors.green, gui = 'bold' } }, insert = { a = { fg = colors.white, bg = colors.green, gui = 'bold' } },
visual = { a = { fg = colors.white, bg = colors.purple, gui = 'bold' } }, visual = { a = { fg = colors.white, bg = colors.purple, gui = 'bold' } },
@ -33,6 +33,6 @@ return {
inactive = { inactive = {
a = { fg = colors.silver, bg = colors.gray, gui = 'bold' }, a = { fg = colors.silver, bg = colors.gray, gui = 'bold' },
b = { fg = colors.gray, bg = colors.black }, b = { fg = colors.gray, bg = colors.black },
c = {fg = colors.silver, bg = colors.black} c = { fg = colors.silver, bg = colors.black },
} },
} }

View File

@ -18,26 +18,26 @@ return {
insert = { insert = {
a = { fg = colors.color0, bg = colors.color1, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color1, gui = 'bold' },
b = { fg = colors.color0, bg = colors.color2 }, b = { fg = colors.color0, bg = colors.color2 },
c = {fg = colors.color0, bg = colors.color3} c = { fg = colors.color0, bg = colors.color3 },
}, },
normal = { normal = {
a = { fg = colors.color0, bg = colors.color4, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color4, gui = 'bold' },
b = { fg = colors.color0, bg = colors.color2 }, b = { fg = colors.color0, bg = colors.color2 },
c = {fg = colors.color0, bg = colors.color3} c = { fg = colors.color0, bg = colors.color3 },
}, },
inactive = { inactive = {
a = { fg = colors.color5, bg = colors.color2, gui = 'bold' }, a = { fg = colors.color5, bg = colors.color2, gui = 'bold' },
b = { fg = colors.color5, bg = colors.color3 }, b = { fg = colors.color5, bg = colors.color3 },
c = {fg = colors.color2, bg = colors.color3} c = { fg = colors.color2, bg = colors.color3 },
}, },
visual = { visual = {
a = { fg = colors.color0, bg = colors.color6, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color6, gui = 'bold' },
b = { fg = colors.color0, bg = colors.color2 }, b = { fg = colors.color0, bg = colors.color2 },
c = {fg = colors.color0, bg = colors.color3} c = { fg = colors.color0, bg = colors.color3 },
}, },
replace = { replace = {
a = { fg = colors.color0, bg = colors.color7, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color7, gui = 'bold' },
b = { fg = colors.color0, bg = colors.color2 }, b = { fg = colors.color0, bg = colors.color2 },
c = {fg = colors.color0, bg = colors.color3} c = { fg = colors.color0, bg = colors.color3 },
} },
} }

View File

@ -21,23 +21,23 @@ return {
inactive = { inactive = {
a = { fg = colors.color0, bg = colors.color1, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color1, gui = 'bold' },
b = { fg = colors.color2, bg = colors.color3 }, b = { fg = colors.color2, bg = colors.color3 },
c = {fg = colors.color0, bg = colors.color1} c = { fg = colors.color0, bg = colors.color1 },
}, },
normal = { normal = {
a = { fg = colors.color1, bg = colors.color4, gui = 'bold' }, a = { fg = colors.color1, bg = colors.color4, gui = 'bold' },
b = { fg = colors.color5, bg = colors.color6 }, b = { fg = colors.color5, bg = colors.color6 },
c = {fg = colors.color7, bg = colors.color1} c = { fg = colors.color7, bg = colors.color1 },
}, },
visual = { visual = {
a = { fg = colors.color1, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color1, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color5, bg = colors.color6} b = { fg = colors.color5, bg = colors.color6 },
}, },
replace = { replace = {
a = { fg = colors.color1, bg = colors.color11, gui = 'bold' }, a = { fg = colors.color1, bg = colors.color11, gui = 'bold' },
b = {fg = colors.color5, bg = colors.color6} b = { fg = colors.color5, bg = colors.color6 },
}, },
insert = { insert = {
a = { fg = colors.color1, bg = colors.color14, gui = 'bold' }, a = { fg = colors.color1, bg = colors.color14, gui = 'bold' },
b = {fg = colors.color5, bg = colors.color6} b = { fg = colors.color5, bg = colors.color6 },
} },
} }

View File

@ -6,7 +6,9 @@ if color_name then
-- Check if there's a theme for current colorscheme -- Check if there's a theme for current colorscheme
-- If there is load that instead of genarating a new one -- If there is load that instead of genarating a new one
local ok, theme = pcall(loader.load_theme, color_name) local ok, theme = pcall(loader.load_theme, color_name)
if ok and theme then return theme end if ok and theme then
return theme
end
end end
--------------- ---------------
@ -30,7 +32,9 @@ local function getHi(scope, syntaxlist)
scope = 'bg' scope = 'bg'
end end
end end
if color[scope] then return color[scope] end if color[scope] then
return color[scope]
end
end end
end end
return '#000000' return '#000000'
@ -38,7 +42,7 @@ end
-- truns #rrggbb -> { red, green, blue } -- truns #rrggbb -> { red, green, blue }
local function rgb_str2num(rgb_color_str) local function rgb_str2num(rgb_color_str)
if rgb_color_str:find('#') == 1 then if rgb_color_str:find '#' == 1 then
rgb_color_str = rgb_color_str:sub(2, #rgb_color_str) rgb_color_str = rgb_color_str:sub(2, #rgb_color_str)
end end
local red = tonumber(rgb_color_str:sub(1, 2), 16) local red = tonumber(rgb_color_str:sub(1, 2), 16)
@ -49,8 +53,7 @@ end
-- turns { red, green, blue } -> #rrggbb -- turns { red, green, blue } -> #rrggbb
local function rgb_num2str(rgb_color_num) local function rgb_num2str(rgb_color_num)
local rgb_color_str = string.format('#%02x%02x%02x', rgb_color_num.red, local rgb_color_str = string.format('#%02x%02x%02x', rgb_color_num.red, rgb_color_num.green, rgb_color_num.blue)
rgb_color_num.green, rgb_color_num.blue)
return rgb_color_str return rgb_color_str
end end
@ -71,8 +74,12 @@ end
-- clamps the val between left and right -- clamps the val between left and right
local function clamp(val, left, right) local function clamp(val, left, right)
if val > right then return right end if val > right then
if val < left then return left end return right
end
if val < left then
return left
end
return val return val
end end
@ -100,18 +107,22 @@ local function apply_contrast(highlight)
local hightlight_bg_avg = get_color_avg(highlight.bg) local hightlight_bg_avg = get_color_avg(highlight.bg)
local contrast_threshold_config = clamp(contrast_threshold, 0, 0.5) local contrast_threshold_config = clamp(contrast_threshold, 0, 0.5)
local contranst_change_step = 5 local contranst_change_step = 5
if hightlight_bg_avg > .5 then contranst_change_step = -contranst_change_step end if hightlight_bg_avg > 0.5 then
contranst_change_step = -contranst_change_step
end
-- donn't waste too much time here max 25 interation should be more than enough -- donn't waste too much time here max 25 interation should be more than enough
local iteration_count = 1 local iteration_count = 1
while (math.abs(get_color_avg(highlight.fg) - hightlight_bg_avg) < while
contrast_threshold_config and iteration_count < 25) do math.abs(get_color_avg(highlight.fg) - hightlight_bg_avg) < contrast_threshold_config and iteration_count < 25
do
highlight.fg = contrast_modifier(highlight.fg, contranst_change_step) highlight.fg = contrast_modifier(highlight.fg, contranst_change_step)
iteration_count = iteration_count + 1 iteration_count = iteration_count + 1
end end
end end
-- Get the colors to create theme -- Get the colors to create theme
-- stylua: ignore
local colors = { local colors = {
normal = getHi('bg', { 'PmenuSel', 'PmenuThumb', 'TabLineSel' }), normal = getHi('bg', { 'PmenuSel', 'PmenuThumb', 'TabLineSel' }),
insert = getHi('fg', { 'String', 'MoreMsg' }), insert = getHi('fg', { 'String', 'MoreMsg' }),
@ -120,7 +131,7 @@ local colors = {
command = getHi('fg', { 'Identifier' }), command = getHi('fg', { 'Identifier' }),
back1 = getHi('bg', { 'Normal', 'StatusLineNC' }), back1 = getHi('bg', { 'Normal', 'StatusLineNC' }),
fore = getHi('fg', { 'Normal', 'StatusLine' }), fore = getHi('fg', { 'Normal', 'StatusLine' }),
back2 = getHi('bg', {'StatusLine'}) back2 = getHi('bg', { 'StatusLine' }),
} }
-- Change brightness of colors -- Change brightness of colors
@ -141,28 +152,28 @@ local M = {
normal = { normal = {
a = { bg = colors.normal, fg = colors.back1, gui = 'bold' }, a = { bg = colors.normal, fg = colors.back1, gui = 'bold' },
b = { bg = colors.back1, fg = colors.normal }, b = { bg = colors.back1, fg = colors.normal },
c = {bg = colors.back2, fg = colors.fore} c = { bg = colors.back2, fg = colors.fore },
}, },
insert = { insert = {
a = { bg = colors.insert, fg = colors.back1, gui = 'bold' }, a = { bg = colors.insert, fg = colors.back1, gui = 'bold' },
b = { bg = colors.back1, fg = colors.insert }, b = { bg = colors.back1, fg = colors.insert },
c = {bg = colors.back2, fg = colors.fore} c = { bg = colors.back2, fg = colors.fore },
}, },
replace = { replace = {
a = { bg = colors.replace, fg = colors.back1, gui = 'bold' }, a = { bg = colors.replace, fg = colors.back1, gui = 'bold' },
b = { bg = colors.back1, fg = colors.replace }, b = { bg = colors.back1, fg = colors.replace },
c = {bg = colors.back2, fg = colors.fore} c = { bg = colors.back2, fg = colors.fore },
}, },
visual = { visual = {
a = { bg = colors.visual, fg = colors.back1, gui = 'bold' }, a = { bg = colors.visual, fg = colors.back1, gui = 'bold' },
b = { bg = colors.back1, fg = colors.visual }, b = { bg = colors.back1, fg = colors.visual },
c = {bg = colors.back2, fg = colors.fore} c = { bg = colors.back2, fg = colors.fore },
}, },
command = { command = {
a = { bg = colors.command, fg = colors.back1, gui = 'bold' }, a = { bg = colors.command, fg = colors.back1, gui = 'bold' },
b = { bg = colors.back1, fg = colors.command }, b = { bg = colors.back1, fg = colors.command },
c = {bg = colors.back2, fg = colors.fore} c = { bg = colors.back2, fg = colors.fore },
} },
} }
M.terminal = M.command M.terminal = M.command
@ -170,7 +181,9 @@ M.inactive = M.normal
-- Apply prpper contrast so text is readable -- Apply prpper contrast so text is readable
for _, section in pairs(M) do for _, section in pairs(M) do
for _, highlight in pairs(section) do apply_contrast(highlight) end for _, highlight in pairs(section) do
apply_contrast(highlight)
end
end end
return M return M

View File

@ -17,24 +17,24 @@ local colors = {
return { return {
visual = { visual = {
a = { fg = colors.color2, bg = colors.color3, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color3, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
replace = { replace = {
a = { fg = colors.color2, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
inactive = { inactive = {
c = { fg = colors.color4, bg = colors.color2 }, c = { fg = colors.color4, bg = colors.color2 },
a = { fg = colors.color4, bg = colors.color5, gui = 'bold' }, a = { fg = colors.color4, bg = colors.color5, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
normal = { normal = {
c = { fg = colors.color9, bg = colors.color2 }, c = { fg = colors.color9, bg = colors.color2 },
a = { fg = colors.color2, bg = colors.color10, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color10, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
insert = { insert = {
a = { fg = colors.color2, bg = colors.color13, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color13, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
} },
} }

View File

@ -17,24 +17,24 @@ local colors = {
return { return {
visual = { visual = {
a = { fg = colors.color2, bg = colors.color3, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color3, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
replace = { replace = {
a = { fg = colors.color2, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
inactive = { inactive = {
c = { fg = colors.color4, bg = colors.color2 }, c = { fg = colors.color4, bg = colors.color2 },
a = { fg = colors.color4, bg = colors.color5, gui = 'bold' }, a = { fg = colors.color4, bg = colors.color5, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
normal = { normal = {
c = { fg = colors.color9, bg = colors.color2 }, c = { fg = colors.color9, bg = colors.color2 },
a = { fg = colors.color2, bg = colors.color10, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color10, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
insert = { insert = {
a = { fg = colors.color2, bg = colors.color13, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color13, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
} },
} }

View File

@ -17,24 +17,24 @@ local colors = {
return { return {
visual = { visual = {
a = { fg = colors.color2, bg = colors.color3, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color3, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
replace = { replace = {
a = { fg = colors.color2, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
inactive = { inactive = {
c = { fg = colors.color4, bg = colors.color2 }, c = { fg = colors.color4, bg = colors.color2 },
a = { fg = colors.color4, bg = colors.color5, gui = 'bold' }, a = { fg = colors.color4, bg = colors.color5, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
normal = { normal = {
c = { fg = colors.color9, bg = colors.color2 }, c = { fg = colors.color9, bg = colors.color2 },
a = { fg = colors.color2, bg = colors.color10, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color10, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
insert = { insert = {
a = { fg = colors.color2, bg = colors.color13, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color13, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
} },
} }

View File

@ -15,24 +15,24 @@ return {
normal = { normal = {
b = { fg = colors.green, bg = colors.black }, b = { fg = colors.green, bg = colors.black },
a = { fg = colors.black, bg = colors.green, gui = 'bold' }, a = { fg = colors.black, bg = colors.green, gui = 'bold' },
c = {fg = colors.white, bg = colors.black} c = { fg = colors.white, bg = colors.black },
}, },
visual = { visual = {
b = { fg = colors.pink, bg = colors.black }, b = { fg = colors.pink, bg = colors.black },
a = {fg = colors.black, bg = colors.pink, gui = 'bold'} a = { fg = colors.black, bg = colors.pink, gui = 'bold' },
}, },
inactive = { inactive = {
b = { fg = colors.black, bg = colors.blue }, b = { fg = colors.black, bg = colors.blue },
a = {fg = colors.white, bg = colors.gray, gui = 'bold'} a = { fg = colors.white, bg = colors.gray, gui = 'bold' },
}, },
replace = { replace = {
b = { fg = colors.lightred, bg = colors.black }, b = { fg = colors.lightred, bg = colors.black },
a = { fg = colors.black, bg = colors.lightred, gui = 'bold' }, a = { fg = colors.black, bg = colors.lightred, gui = 'bold' },
c = {fg = colors.white, bg = colors.black} c = { fg = colors.white, bg = colors.black },
}, },
insert = { insert = {
b = { fg = colors.blue, bg = colors.black }, b = { fg = colors.blue, bg = colors.black },
a = { fg = colors.black, bg = colors.blue, gui = 'bold' }, a = { fg = colors.black, bg = colors.blue, gui = 'bold' },
c = {fg = colors.white, bg = colors.black} c = { fg = colors.white, bg = colors.black },
} },
} }

View File

@ -18,31 +18,31 @@ return {
normal = { normal = {
a = { bg = colors.purple, fg = colors.black, gui = 'bold' }, a = { bg = colors.purple, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
insert = { insert = {
a = { bg = colors.green, fg = colors.black, gui = 'bold' }, a = { bg = colors.green, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
visual = { visual = {
a = { bg = colors.yellow, fg = colors.black, gui = 'bold' }, a = { bg = colors.yellow, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
replace = { replace = {
a = { bg = colors.red, fg = colors.black, gui = 'bold' }, a = { bg = colors.red, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
command = { command = {
a = { bg = colors.orange, fg = colors.black, gui = 'bold' }, a = { bg = colors.orange, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
inactive = { inactive = {
a = { bg = colors.gray, fg = colors.white, gui = 'bold' }, a = { bg = colors.gray, fg = colors.white, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
} },
} }

View File

@ -18,36 +18,36 @@ return {
normal = { normal = {
a = { bg = colors.green, fg = colors.bg0, gui = 'bold' }, a = { bg = colors.green, fg = colors.bg0, gui = 'bold' },
b = { bg = colors.bg3, fg = colors.fg }, b = { bg = colors.bg3, fg = colors.fg },
c = {bg = colors.bg1, fg = colors.fg} c = { bg = colors.bg1, fg = colors.fg },
}, },
insert = { insert = {
a = { bg = colors.fg, fg = colors.bg0, gui = 'bold' }, a = { bg = colors.fg, fg = colors.bg0, gui = 'bold' },
b = { bg = colors.bg3, fg = colors.fg }, b = { bg = colors.bg3, fg = colors.fg },
c = {bg = colors.bg1, fg = colors.fg} c = { bg = colors.bg1, fg = colors.fg },
}, },
visual = { visual = {
a = { bg = colors.red, fg = colors.bg0, gui = 'bold' }, a = { bg = colors.red, fg = colors.bg0, gui = 'bold' },
b = { bg = colors.bg3, fg = colors.fg }, b = { bg = colors.bg3, fg = colors.fg },
c = {bg = colors.bg1, fg = colors.fg} c = { bg = colors.bg1, fg = colors.fg },
}, },
replace = { replace = {
a = { bg = colors.orange, fg = colors.bg0, gui = 'bold' }, a = { bg = colors.orange, fg = colors.bg0, gui = 'bold' },
b = { bg = colors.bg3, fg = colors.fg }, b = { bg = colors.bg3, fg = colors.fg },
c = {bg = colors.bg1, fg = colors.fg} c = { bg = colors.bg1, fg = colors.fg },
}, },
command = { command = {
a = { bg = colors.aqua, fg = colors.bg0, gui = 'bold' }, a = { bg = colors.aqua, fg = colors.bg0, gui = 'bold' },
b = { bg = colors.bg3, fg = colors.fg }, b = { bg = colors.bg3, fg = colors.fg },
c = {bg = colors.bg1, fg = colors.fg} c = { bg = colors.bg1, fg = colors.fg },
}, },
terminal = { terminal = {
a = { bg = colors.purple, fg = colors.bg0, gui = 'bold' }, a = { bg = colors.purple, fg = colors.bg0, gui = 'bold' },
b = { bg = colors.bg3, fg = colors.fg }, b = { bg = colors.bg3, fg = colors.fg },
c = {bg = colors.bg1, fg = colors.fg} c = { bg = colors.bg1, fg = colors.fg },
}, },
inactive = { inactive = {
a = { bg = colors.bg1, fg = colors.grey1, gui = 'bold' }, a = { bg = colors.bg1, fg = colors.grey1, gui = 'bold' },
b = { bg = colors.bg1, fg = colors.grey1 }, b = { bg = colors.bg1, fg = colors.grey1 },
c = {bg = colors.bg1, fg = colors.grey1} c = { bg = colors.bg1, fg = colors.grey1 },
} },
} }

View File

@ -18,12 +18,12 @@ return {
normal = { normal = {
a = { fg = colors.fg1, bg = colors.color4, gui = 'bold' }, a = { fg = colors.fg1, bg = colors.color4, gui = 'bold' },
b = { fg = colors.fg2, bg = colors.color2 }, b = { fg = colors.fg2, bg = colors.color2 },
c = {fg = colors.fg2, bg = colors.color3} c = { fg = colors.fg2, bg = colors.color3 },
}, },
command = { a = { fg = colors.fg1, bg = colors.color5, gui = 'bold' } }, command = { a = { fg = colors.fg1, bg = colors.color5, gui = 'bold' } },
inactive = { a = { fg = colors.fg2, bg = colors.color2 } }, inactive = { a = { fg = colors.fg2, bg = colors.color2 } },
insert = { a = { fg = colors.fg1, bg = colors.color6, gui = 'bold' } }, insert = { a = { fg = colors.fg1, bg = colors.color6, gui = 'bold' } },
replace = { a = { fg = colors.fg1, bg = colors.color7, gui = 'bold' } }, replace = { a = { fg = colors.fg1, bg = colors.color7, gui = 'bold' } },
terminal = { a = { fg = colors.fg1, bg = colors.color8, gui = 'bold' } }, terminal = { a = { fg = colors.fg1, bg = colors.color8, gui = 'bold' } },
visual = {a = {fg = colors.fg1, bg = colors.color9, gui = 'bold'}} visual = { a = { fg = colors.fg1, bg = colors.color9, gui = 'bold' } },
} }

View File

@ -18,31 +18,31 @@ return {
normal = { normal = {
a = { bg = colors.gray, fg = colors.black, gui = 'bold' }, a = { bg = colors.gray, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.darkgray, fg = colors.gray} c = { bg = colors.darkgray, fg = colors.gray },
}, },
insert = { insert = {
a = { bg = colors.blue, fg = colors.black, gui = 'bold' }, a = { bg = colors.blue, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.lightgray, fg = colors.white} c = { bg = colors.lightgray, fg = colors.white },
}, },
visual = { visual = {
a = { bg = colors.yellow, fg = colors.black, gui = 'bold' }, a = { bg = colors.yellow, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.inactivegray, fg = colors.black} c = { bg = colors.inactivegray, fg = colors.black },
}, },
replace = { replace = {
a = { bg = colors.red, fg = colors.black, gui = 'bold' }, a = { bg = colors.red, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.black, fg = colors.white} c = { bg = colors.black, fg = colors.white },
}, },
command = { command = {
a = { bg = colors.green, fg = colors.black, gui = 'bold' }, a = { bg = colors.green, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.inactivegray, fg = colors.black} c = { bg = colors.inactivegray, fg = colors.black },
}, },
inactive = { inactive = {
a = { bg = colors.darkgray, fg = colors.gray, gui = 'bold' }, a = { bg = colors.darkgray, fg = colors.gray, gui = 'bold' },
b = { bg = colors.darkgray, fg = colors.gray }, b = { bg = colors.darkgray, fg = colors.gray },
c = {bg = colors.darkgray, fg = colors.gray} c = { bg = colors.darkgray, fg = colors.gray },
} },
} }

View File

@ -41,5 +41,5 @@ return {
a = { bg = colors.lightgray, fg = colors.inactivegray }, a = { bg = colors.lightgray, fg = colors.inactivegray },
b = { bg = colors.lightgray, fg = colors.inactivegray }, b = { bg = colors.lightgray, fg = colors.inactivegray },
c = { bg = colors.lightgray, fg = colors.inactivegray }, c = { bg = colors.lightgray, fg = colors.inactivegray },
} },
} }

View File

@ -23,26 +23,26 @@ return {
insert = { insert = {
a = { bg = colors.blue, fg = colors.black, gui = 'bold' }, a = { bg = colors.blue, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.darkgray, fg = colors.white} c = { bg = colors.darkgray, fg = colors.white },
}, },
visual = { visual = {
a = { bg = colors.yellow, fg = colors.black, gui = 'bold' }, a = { bg = colors.yellow, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.darkgray, fg = colors.white} c = { bg = colors.darkgray, fg = colors.white },
}, },
replace = { replace = {
a = { bg = colors.red, fg = colors.black, gui = 'bold' }, a = { bg = colors.red, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.darkgray, fg = colors.white} c = { bg = colors.darkgray, fg = colors.white },
}, },
command = { command = {
a = { bg = colors.green, fg = colors.black, gui = 'bold' }, a = { bg = colors.green, fg = colors.black, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.white }, b = { bg = colors.lightgray, fg = colors.white },
c = {bg = colors.darkgray, fg = colors.white} c = { bg = colors.darkgray, fg = colors.white },
}, },
inactive = { inactive = {
a = { bg = colors.inactivegray, fg = colors.lightgray, gui = 'bold' }, a = { bg = colors.inactivegray, fg = colors.lightgray, gui = 'bold' },
b = { bg = colors.inactivegray, fg = colors.lightgray }, b = { bg = colors.inactivegray, fg = colors.lightgray },
c = {bg = colors.inactivegray, fg = colors.lightgray} c = { bg = colors.inactivegray, fg = colors.lightgray },
} },
} }

View File

@ -19,24 +19,24 @@ local colors = {
return { return {
visual = { visual = {
a = { fg = colors.color2, bg = colors.color3, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color3, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
replace = { replace = {
a = { fg = colors.color2, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
inactive = { inactive = {
c = { fg = colors.color9, bg = colors.color10 }, c = { fg = colors.color9, bg = colors.color10 },
a = { fg = colors.color9, bg = colors.color10, gui = 'bold' }, a = { fg = colors.color9, bg = colors.color10, gui = 'bold' },
b = {fg = colors.color9, bg = colors.color10} b = { fg = colors.color9, bg = colors.color10 },
}, },
normal = { normal = {
c = { fg = colors.color9, bg = colors.color10 }, c = { fg = colors.color9, bg = colors.color10 },
a = { fg = colors.color11, bg = colors.color12, gui = 'bold' }, a = { fg = colors.color11, bg = colors.color12, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
insert = { insert = {
a = { fg = colors.color2, bg = colors.color15, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color15, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
} },
} }

View File

@ -17,24 +17,24 @@ local colors = {
return { return {
replace = { replace = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
a = {fg = colors.color0, bg = colors.color2, gui = 'bold'} a = { fg = colors.color0, bg = colors.color2, gui = 'bold' },
}, },
visual = { visual = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
a = {fg = colors.color0, bg = colors.color5, gui = 'bold'} a = { fg = colors.color0, bg = colors.color5, gui = 'bold' },
}, },
normal = { normal = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
a = { fg = colors.color0, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color8, gui = 'bold' },
c = {fg = colors.color9, bg = colors.color10} c = { fg = colors.color9, bg = colors.color10 },
}, },
inactive = { inactive = {
b = { fg = colors.color9, bg = colors.color10 }, b = { fg = colors.color9, bg = colors.color10 },
a = { fg = colors.color9, bg = colors.color10, gui = 'bold' }, a = { fg = colors.color9, bg = colors.color10, gui = 'bold' },
c = {fg = colors.color9, bg = colors.color10} c = { fg = colors.color9, bg = colors.color10 },
}, },
insert = { insert = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
a = {fg = colors.color0, bg = colors.color11, gui = 'bold'} a = { fg = colors.color0, bg = colors.color11, gui = 'bold' },
} },
} }

View File

@ -18,24 +18,24 @@ local colors = {
return { return {
visual = { visual = {
a = { fg = colors.color2, bg = colors.color3, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color3, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
replace = { replace = {
a = { fg = colors.color2, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
inactive = { inactive = {
c = { fg = colors.color9, bg = colors.color2 }, c = { fg = colors.color9, bg = colors.color2 },
a = { fg = colors.color10, bg = colors.color2, gui = 'bold' }, a = { fg = colors.color10, bg = colors.color2, gui = 'bold' },
b = {fg = colors.color9, bg = colors.color2} b = { fg = colors.color9, bg = colors.color2 },
}, },
normal = { normal = {
c = { fg = colors.color10, bg = colors.color2 }, c = { fg = colors.color10, bg = colors.color2 },
a = { fg = colors.color2, bg = colors.color11, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color11, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
}, },
insert = { insert = {
a = { fg = colors.color2, bg = colors.color14, gui = 'bold' }, a = { fg = colors.color2, bg = colors.color14, gui = 'bold' },
b = {fg = colors.color4, bg = colors.color5} b = { fg = colors.color4, bg = colors.color5 },
} },
} }

View File

@ -20,23 +20,23 @@ return {
normal = { normal = {
a = { fg = colors.bg, bg = colors.blue, gui = 'bold' }, a = { fg = colors.bg, bg = colors.blue, gui = 'bold' },
b = { fg = colors.fg, bg = colors.gray3 }, b = { fg = colors.fg, bg = colors.gray3 },
c = {fg = colors.fg, bg = colors.gray2} c = { fg = colors.fg, bg = colors.gray2 },
}, },
insert = { insert = {
a = { fg = colors.bg, bg = colors.green, gui = 'bold' }, a = { fg = colors.bg, bg = colors.green, gui = 'bold' },
b = {fg = colors.fg, bg = colors.gray3} b = { fg = colors.fg, bg = colors.gray3 },
}, },
visual = { visual = {
a = { fg = colors.bg, bg = colors.purple, gui = 'bold' }, a = { fg = colors.bg, bg = colors.purple, gui = 'bold' },
b = {fg = colors.fg, bg = colors.gray3} b = { fg = colors.fg, bg = colors.gray3 },
}, },
replace = { replace = {
a = { fg = colors.bg, bg = colors.red1, gui = 'bold' }, a = { fg = colors.bg, bg = colors.red1, gui = 'bold' },
b = {fg = colors.fg, bg = colors.gray3} b = { fg = colors.fg, bg = colors.gray3 },
}, },
inactive = { inactive = {
a = { fg = colors.fg, bg = colors.bg, gui = 'bold' }, a = { fg = colors.fg, bg = colors.bg, gui = 'bold' },
b = { fg = colors.fg, bg = colors.bg }, b = { fg = colors.fg, bg = colors.bg },
c = {fg = colors.fg, bg = colors.gray2} c = { fg = colors.fg, bg = colors.gray2 },
} },
} }

View File

@ -18,31 +18,31 @@ return {
normal = { normal = {
a = { bg = colors.blue, fg = colors.lightgray, gui = 'bold' }, a = { bg = colors.blue, fg = colors.lightgray, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.blue }, b = { bg = colors.lightgray, fg = colors.blue },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
insert = { insert = {
a = { bg = colors.cyan, fg = colors.lightgray, gui = 'bold' }, a = { bg = colors.cyan, fg = colors.lightgray, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.cyan }, b = { bg = colors.lightgray, fg = colors.cyan },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
visual = { visual = {
a = { bg = colors.magenta, fg = colors.lightgray, gui = 'bold' }, a = { bg = colors.magenta, fg = colors.lightgray, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.magenta }, b = { bg = colors.lightgray, fg = colors.magenta },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
replace = { replace = {
a = { bg = colors.red, fg = colors.lightgray, gui = 'bold' }, a = { bg = colors.red, fg = colors.lightgray, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.red }, b = { bg = colors.lightgray, fg = colors.red },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
command = { command = {
a = { bg = colors.green, fg = colors.lightgray, gui = 'bold' }, a = { bg = colors.green, fg = colors.lightgray, gui = 'bold' },
b = { bg = colors.lightgray, fg = colors.green }, b = { bg = colors.lightgray, fg = colors.green },
c = {bg = colors.gray, fg = colors.white} c = { bg = colors.gray, fg = colors.white },
}, },
inactive = { inactive = {
a = { bg = colors.darkgray, fg = colors.lightgray, gui = 'bold' }, a = { bg = colors.darkgray, fg = colors.lightgray, gui = 'bold' },
b = { bg = colors.darkgray, fg = colors.lightgray }, b = { bg = colors.darkgray, fg = colors.lightgray },
c = {bg = colors.darkgray, fg = colors.lightgray} c = { bg = colors.darkgray, fg = colors.lightgray },
} },
} }

View File

@ -18,7 +18,7 @@ return {
normal = { normal = {
a = { fg = colors.black, bg = colors.cyan, gui = 'bold' }, a = { fg = colors.black, bg = colors.cyan, gui = 'bold' },
b = { fg = colors.black, bg = colors.pink }, b = { fg = colors.black, bg = colors.pink },
c = {fg = colors.orange, bg = colors.black} c = { fg = colors.orange, bg = colors.black },
}, },
insert = { a = { fg = colors.black, bg = colors.green, gui = 'bold' } }, insert = { a = { fg = colors.black, bg = colors.green, gui = 'bold' } },
visual = { a = { fg = colors.black, bg = colors.yellow, gui = 'bold' } }, visual = { a = { fg = colors.black, bg = colors.yellow, gui = 'bold' } },
@ -26,6 +26,6 @@ return {
inactive = { inactive = {
a = { fg = colors.pink, bg = colors.black, gui = 'bold' }, a = { fg = colors.pink, bg = colors.black, gui = 'bold' },
b = { fg = colors.white, bg = colors.pink }, b = { fg = colors.white, bg = colors.pink },
c = {fg = colors.gray, bg = colors.black} c = { fg = colors.gray, bg = colors.black },
} },
} }

View File

@ -17,24 +17,24 @@ local colors = {
return { return {
replace = { replace = {
a = { fg = colors.color0, bg = colors.color1, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color1, gui = 'bold' },
b = {fg = colors.color2, bg = colors.color3} b = { fg = colors.color2, bg = colors.color3 },
}, },
inactive = { inactive = {
a = { fg = colors.color6, bg = colors.color3, gui = 'bold' }, a = { fg = colors.color6, bg = colors.color3, gui = 'bold' },
b = { fg = colors.color6, bg = colors.color3 }, b = { fg = colors.color6, bg = colors.color3 },
c = {fg = colors.color6, bg = colors.color3} c = { fg = colors.color6, bg = colors.color3 },
}, },
normal = { normal = {
a = { fg = colors.color0, bg = colors.color7, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color7, gui = 'bold' },
b = { fg = colors.color2, bg = colors.color3 }, b = { fg = colors.color2, bg = colors.color3 },
c = {fg = colors.color2, bg = colors.color3} c = { fg = colors.color2, bg = colors.color3 },
}, },
visual = { visual = {
a = { fg = colors.color0, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color2, bg = colors.color3} b = { fg = colors.color2, bg = colors.color3 },
}, },
insert = { insert = {
a = { fg = colors.color0, bg = colors.color2, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color2, gui = 'bold' },
b = {fg = colors.color2, bg = colors.color3} b = { fg = colors.color2, bg = colors.color3 },
} },
} }

View File

@ -14,24 +14,24 @@ local colors = {
return { return {
replace = { replace = {
a = { fg = colors.color0, bg = colors.color1, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color1, gui = 'bold' },
b = {fg = colors.color2, bg = colors.color3} b = { fg = colors.color2, bg = colors.color3 },
}, },
inactive = { inactive = {
a = { fg = colors.color6, bg = colors.color3, gui = 'bold' }, a = { fg = colors.color6, bg = colors.color3, gui = 'bold' },
b = { fg = colors.color6, bg = colors.color3 }, b = { fg = colors.color6, bg = colors.color3 },
c = {fg = colors.color6, bg = colors.color3} c = { fg = colors.color6, bg = colors.color3 },
}, },
normal = { normal = {
a = { fg = colors.color0, bg = colors.color7, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color7, gui = 'bold' },
b = { fg = colors.color2, bg = colors.color3 }, b = { fg = colors.color2, bg = colors.color3 },
c = {fg = colors.color2, bg = colors.color3} c = { fg = colors.color2, bg = colors.color3 },
}, },
visual = { visual = {
a = { fg = colors.color0, bg = colors.color8, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color8, gui = 'bold' },
b = {fg = colors.color2, bg = colors.color3} b = { fg = colors.color2, bg = colors.color3 },
}, },
insert = { insert = {
a = { fg = colors.color0, bg = colors.color2, gui = 'bold' }, a = { fg = colors.color0, bg = colors.color2, gui = 'bold' },
b = {fg = colors.color2, bg = colors.color3} b = { fg = colors.color2, bg = colors.color3 },
} },
} }

View File

@ -15,7 +15,7 @@ return {
normal = { normal = {
a = { fg = colors.nord1, bg = colors.nord8, gui = 'bold' }, a = { fg = colors.nord1, bg = colors.nord8, gui = 'bold' },
b = { fg = colors.nord5, bg = colors.nord1 }, b = { fg = colors.nord5, bg = colors.nord1 },
c = {fg = colors.nord5, bg = colors.nord3} c = { fg = colors.nord5, bg = colors.nord3 },
}, },
insert = { a = { fg = colors.nord1, bg = colors.nord6, gui = 'bold' } }, insert = { a = { fg = colors.nord1, bg = colors.nord6, gui = 'bold' } },
visual = { a = { fg = colors.nord1, bg = colors.nord7, gui = 'bold' } }, visual = { a = { fg = colors.nord1, bg = colors.nord7, gui = 'bold' } },
@ -23,7 +23,6 @@ return {
inactive = { inactive = {
a = { fg = colors.nord1, bg = colors.nord8, gui = 'bold' }, a = { fg = colors.nord1, bg = colors.nord8, gui = 'bold' },
b = { fg = colors.nord5, bg = colors.nord1 }, b = { fg = colors.nord5, bg = colors.nord1 },
c = {fg = colors.nord5, bg = colors.nord1} c = { fg = colors.nord5, bg = colors.nord1 },
},
} }
}

View File

@ -20,7 +20,7 @@ return {
normal = { normal = {
a = { fg = colors.bg, bg = colors.green, gui = 'bold' }, a = { fg = colors.bg, bg = colors.green, gui = 'bold' },
b = { fg = colors.fg, bg = colors.gray3 }, b = { fg = colors.fg, bg = colors.gray3 },
c = {fg = colors.fg, bg = colors.gray2} c = { fg = colors.fg, bg = colors.gray2 },
}, },
insert = { a = { fg = colors.bg, bg = colors.blue, gui = 'bold' } }, insert = { a = { fg = colors.bg, bg = colors.blue, gui = 'bold' } },
visual = { a = { fg = colors.bg, bg = colors.purple, gui = 'bold' } }, visual = { a = { fg = colors.bg, bg = colors.purple, gui = 'bold' } },
@ -28,6 +28,6 @@ return {
inactive = { inactive = {
a = { fg = colors.gray1, bg = colors.bg, gui = 'bold' }, a = { fg = colors.gray1, bg = colors.bg, gui = 'bold' },
b = { fg = colors.gray1, bg = colors.bg }, b = { fg = colors.gray1, bg = colors.bg },
c = {fg = colors.gray1, bg = colors.gray2} c = { fg = colors.gray1, bg = colors.gray2 },
} },
} }

View File

@ -20,7 +20,7 @@ return {
normal = { normal = {
a = { fg = colors.bg, bg = colors.green, gui = 'bold' }, a = { fg = colors.bg, bg = colors.green, gui = 'bold' },
b = { fg = colors.fg, bg = colors.gray3 }, b = { fg = colors.fg, bg = colors.gray3 },
c = {fg = colors.fg, bg = colors.gray2} c = { fg = colors.fg, bg = colors.gray2 },
}, },
insert = { a = { fg = colors.bg, bg = colors.blue, gui = 'bold' } }, insert = { a = { fg = colors.bg, bg = colors.blue, gui = 'bold' } },
visual = { a = { fg = colors.bg, bg = colors.purple, gui = 'bold' } }, visual = { a = { fg = colors.bg, bg = colors.purple, gui = 'bold' } },
@ -28,7 +28,6 @@ return {
inactive = { inactive = {
a = { fg = colors.bg, bg = colors.gray3, gui = 'bold' }, a = { fg = colors.bg, bg = colors.gray3, gui = 'bold' },
b = { fg = colors.bg, bg = colors.gray3 }, b = { fg = colors.bg, bg = colors.gray3 },
c = {fg = colors.gray3, bg = colors.gray2} c = { fg = colors.gray3, bg = colors.gray2 },
} },
} }

View File

@ -25,23 +25,23 @@ return {
normal = { normal = {
a = { fg = colors.black, bg = colors.purple, gui = 'bold' }, a = { fg = colors.black, bg = colors.purple, gui = 'bold' },
b = { fg = colors.purple, bg = colors.menu_grey }, b = { fg = colors.purple, bg = colors.menu_grey },
c = {fg = colors.comment_grey, bg = colors.black} c = { fg = colors.comment_grey, bg = colors.black },
}, },
insert = { insert = {
a = { fg = colors.black, bg = colors.blue, gui = 'bold' }, a = { fg = colors.black, bg = colors.blue, gui = 'bold' },
b = {fg = colors.blue, bg = colors.menu_grey} b = { fg = colors.blue, bg = colors.menu_grey },
}, },
visual = { visual = {
a = { fg = colors.black, bg = colors.cyan, gui = 'bold' }, a = { fg = colors.black, bg = colors.cyan, gui = 'bold' },
b = {fg = colors.cyan, bg = colors.menu_grey} b = { fg = colors.cyan, bg = colors.menu_grey },
}, },
replace = { replace = {
a = { fg = colors.black, bg = colors.green, gui = 'bold' }, a = { fg = colors.black, bg = colors.green, gui = 'bold' },
b = {fg = colors.green, bg = colors.menu_grey} b = { fg = colors.green, bg = colors.menu_grey },
}, },
inactive = { inactive = {
a = { fg = colors.black, bg = colors.menu_grey, gui = 'bold' }, a = { fg = colors.black, bg = colors.menu_grey, gui = 'bold' },
b = { fg = colors.black, bg = colors.menu_grey }, b = { fg = colors.black, bg = colors.menu_grey },
c = {fg = colors.black, bg = colors.menu_grey} c = { fg = colors.black, bg = colors.menu_grey },
} },
} }

View File

@ -29,7 +29,7 @@ return {
normal = { normal = {
a = { fg = colors.foreground, bg = colors.background, gui = 'bold' }, a = { fg = colors.foreground, bg = colors.background, gui = 'bold' },
b = { fg = colors.statusline_active_fg, bg = colors.status }, b = { fg = colors.statusline_active_fg, bg = colors.status },
c = {fg = colors.statusline_active_fg, bg = colors.statusline_active_bg} c = { fg = colors.statusline_active_fg, bg = colors.statusline_active_bg },
}, },
insert = { a = { fg = colors.background, bg = colors.blue, gui = 'bold' } }, insert = { a = { fg = colors.background, bg = colors.blue, gui = 'bold' } },
visual = { a = { fg = colors.visual_fg, bg = colors.visual_bg, gui = 'bold' } }, visual = { a = { fg = colors.visual_fg, bg = colors.visual_bg, gui = 'bold' } },
@ -37,7 +37,6 @@ return {
inactive = { inactive = {
a = { fg = colors.foreground, bg = colors.background, gui = 'bold' }, a = { fg = colors.foreground, bg = colors.background, gui = 'bold' },
b = { fg = colors.foreground, bg = colors.background }, b = { fg = colors.foreground, bg = colors.background },
c = {fg = colors.foreground, bg = colors.background} c = { fg = colors.foreground, bg = colors.background },
} },
} }

View File

@ -27,7 +27,7 @@ return {
normal = { normal = {
a = { fg = colors.foreground, bg = colors.background, gui = 'bold' }, a = { fg = colors.foreground, bg = colors.background, gui = 'bold' },
b = { fg = colors.statusline_active_fg, bg = colors.status }, b = { fg = colors.statusline_active_fg, bg = colors.status },
c = {fg = colors.statusline_active_fg, bg = colors.statusline_active_bg} c = { fg = colors.statusline_active_fg, bg = colors.statusline_active_bg },
}, },
insert = { a = { fg = colors.blue, bg = colors.background, gui = 'bold' } }, insert = { a = { fg = colors.blue, bg = colors.background, gui = 'bold' } },
visual = { a = { fg = colors.background, bg = colors.orange, gui = 'bold' } }, visual = { a = { fg = colors.background, bg = colors.orange, gui = 'bold' } },
@ -35,7 +35,6 @@ return {
inactive = { inactive = {
a = { fg = colors.foreground, bg = colors.background, gui = 'bold' }, a = { fg = colors.foreground, bg = colors.background, gui = 'bold' },
b = { fg = colors.foreground, bg = colors.background }, b = { fg = colors.foreground, bg = colors.background },
c = {fg = colors.foreground, bg = colors.background} c = { fg = colors.foreground, bg = colors.background },
} },
} }

View File

@ -23,18 +23,18 @@ return {
normal = { normal = {
a = { fg = Colors.darkestgreen, bg = Colors.brightgreen, gui = 'bold' }, a = { fg = Colors.darkestgreen, bg = Colors.brightgreen, gui = 'bold' },
b = { fg = Colors.gray10, bg = Colors.gray5 }, b = { fg = Colors.gray10, bg = Colors.gray5 },
c = {fg = Colors.gray7, bg = Colors.gray2} c = { fg = Colors.gray7, bg = Colors.gray2 },
}, },
insert = { insert = {
a = { fg = Colors.darkestcyan, bg = Colors.white, gui = 'bold' }, a = { fg = Colors.darkestcyan, bg = Colors.white, gui = 'bold' },
b = { fg = Colors.darkestcyan, bg = Colors.mediumcyan }, b = { fg = Colors.darkestcyan, bg = Colors.mediumcyan },
c = {fg = Colors.mediumcyan, bg = Colors.darkestblue} c = { fg = Colors.mediumcyan, bg = Colors.darkestblue },
}, },
visual = { a = { fg = Colors.darkred, bg = Colors.brightorange, gui = 'bold' } }, visual = { a = { fg = Colors.darkred, bg = Colors.brightorange, gui = 'bold' } },
replace = { a = { fg = Colors.white, bg = Colors.brightred, gui = 'bold' } }, replace = { a = { fg = Colors.white, bg = Colors.brightred, gui = 'bold' } },
inactive = { inactive = {
a = { fg = Colors.gray1, bg = Colors.gray5, gui = 'bold' }, a = { fg = Colors.gray1, bg = Colors.gray5, gui = 'bold' },
b = { fg = Colors.gray1, bg = Colors.gray5 }, b = { fg = Colors.gray1, bg = Colors.gray5 },
c = {bg = Colors.gray1, fg = Colors.gray5} c = { bg = Colors.gray1, fg = Colors.gray5 },
} },
} }

View File

@ -26,31 +26,31 @@ return {
normal = { normal = {
a = { bg = colors.neon, fg = colors.black, gui = 'bold' }, a = { bg = colors.neon, fg = colors.black, gui = 'bold' },
b = { bg = colors.gray, fg = colors.white }, b = { bg = colors.gray, fg = colors.white },
c = {bg = colors.black, fg = colors.brightgreen} c = { bg = colors.black, fg = colors.brightgreen },
}, },
insert = { insert = {
a = { bg = colors.blue, fg = colors.darkblue, gui = 'bold' }, a = { bg = colors.blue, fg = colors.darkblue, gui = 'bold' },
b = { bg = colors.navyblue, fg = colors.white }, b = { bg = colors.navyblue, fg = colors.white },
c = {bg = colors.purple, fg = colors.white} c = { bg = colors.purple, fg = colors.white },
}, },
visual = { visual = {
a = { bg = colors.orange, fg = colors.black, gui = 'bold' }, a = { bg = colors.orange, fg = colors.black, gui = 'bold' },
b = { bg = colors.darkgray, fg = colors.white }, b = { bg = colors.darkgray, fg = colors.white },
c = {bg = colors.red, fg = colors.white} c = { bg = colors.red, fg = colors.white },
}, },
replace = { replace = {
a = { bg = colors.brightred, fg = colors.white, gui = 'bold' }, a = { bg = colors.brightred, fg = colors.white, gui = 'bold' },
b = { bg = colors.cyan, fg = colors.darkblue }, b = { bg = colors.cyan, fg = colors.darkblue },
c = {bg = colors.navyblue, fg = colors.white} c = { bg = colors.navyblue, fg = colors.white },
}, },
command = { command = {
a = { bg = colors.green, fg = colors.black, gui = 'bold' }, a = { bg = colors.green, fg = colors.black, gui = 'bold' },
b = { bg = colors.darkgray, fg = colors.white }, b = { bg = colors.darkgray, fg = colors.white },
c = {bg = colors.black, fg = colors.brightgreen} c = { bg = colors.black, fg = colors.brightgreen },
}, },
inactive = { inactive = {
a = { bg = colors.darkgray, fg = colors.gray, gui = 'bold' }, a = { bg = colors.darkgray, fg = colors.gray, gui = 'bold' },
b = { bg = colors.darkgray, fg = colors.gray }, b = { bg = colors.darkgray, fg = colors.gray },
c = {bg = colors.darkgray, fg = colors.gray} c = { bg = colors.darkgray, fg = colors.gray },
} },
} }

View File

@ -18,24 +18,24 @@ local colors = {
return { return {
visual = { visual = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
a = {fg = colors.color4, bg = colors.color5, gui = 'bold'} a = { fg = colors.color4, bg = colors.color5, gui = 'bold' },
}, },
inactive = { inactive = {
b = { fg = colors.color6, bg = colors.color4 }, b = { fg = colors.color6, bg = colors.color4 },
c = { fg = colors.color6, bg = colors.color4 }, c = { fg = colors.color6, bg = colors.color4 },
a = {fg = colors.color7, bg = colors.color4, gui = 'bold'} a = { fg = colors.color7, bg = colors.color4, gui = 'bold' },
}, },
insert = { insert = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
a = {fg = colors.color4, bg = colors.color10, gui = 'bold'} a = { fg = colors.color4, bg = colors.color10, gui = 'bold' },
}, },
replace = { replace = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
a = {fg = colors.color4, bg = colors.color13, gui = 'bold'} a = { fg = colors.color4, bg = colors.color13, gui = 'bold' },
}, },
normal = { normal = {
b = { fg = colors.color0, bg = colors.color1 }, b = { fg = colors.color0, bg = colors.color1 },
c = { fg = colors.color7, bg = colors.color4 }, c = { fg = colors.color7, bg = colors.color4 },
a = {fg = colors.color4, bg = colors.color14, gui = 'bold'} a = { fg = colors.color4, bg = colors.color14, gui = 'bold' },
} },
} }

View File

@ -25,7 +25,7 @@ return {
normal = { normal = {
a = { fg = colors.base03, bg = colors.blue, gui = 'bold' }, a = { fg = colors.base03, bg = colors.blue, gui = 'bold' },
b = { fg = colors.base03, bg = colors.base1 }, b = { fg = colors.base03, bg = colors.base1 },
c = {fg = colors.base1, bg = colors.base02} c = { fg = colors.base1, bg = colors.base02 },
}, },
insert = { a = { fg = colors.base03, bg = colors.green, gui = 'bold' } }, insert = { a = { fg = colors.base03, bg = colors.green, gui = 'bold' } },
visual = { a = { fg = colors.base03, bg = colors.magenta, gui = 'bold' } }, visual = { a = { fg = colors.base03, bg = colors.magenta, gui = 'bold' } },
@ -33,6 +33,6 @@ return {
inactive = { inactive = {
a = { fg = colors.base0, bg = colors.base02, gui = 'bold' }, a = { fg = colors.base0, bg = colors.base02, gui = 'bold' },
b = { fg = colors.base03, bg = colors.base00 }, b = { fg = colors.base03, bg = colors.base00 },
c = {fg = colors.base01, bg = colors.base02} c = { fg = colors.base01, bg = colors.base02 },
} },
} }

View File

@ -25,7 +25,7 @@ return {
normal = { normal = {
a = { fg = colors.base03, bg = colors.blue, gui = 'bold' }, a = { fg = colors.base03, bg = colors.blue, gui = 'bold' },
b = { fg = colors.base03, bg = colors.base1 }, b = { fg = colors.base03, bg = colors.base1 },
c = {fg = colors.base1, bg = colors.base02} c = { fg = colors.base1, bg = colors.base02 },
}, },
insert = { a = { fg = colors.base03, bg = colors.green, gui = 'bold' } }, insert = { a = { fg = colors.base03, bg = colors.green, gui = 'bold' } },
visual = { a = { fg = colors.base03, bg = colors.magenta, gui = 'bold' } }, visual = { a = { fg = colors.base03, bg = colors.magenta, gui = 'bold' } },
@ -33,6 +33,6 @@ return {
inactive = { inactive = {
a = { fg = colors.base0, bg = colors.base02, gui = 'bold' }, a = { fg = colors.base0, bg = colors.base02, gui = 'bold' },
b = { fg = colors.base03, bg = colors.base00 }, b = { fg = colors.base03, bg = colors.base00 },
c = {fg = colors.base01, bg = colors.base02} c = { fg = colors.base01, bg = colors.base02 },
} },
} }

View File

@ -25,7 +25,7 @@ return {
normal = { normal = {
a = { fg = colors.base02, bg = colors.blue, gui = 'bold' }, a = { fg = colors.base02, bg = colors.blue, gui = 'bold' },
b = { fg = colors.base02, bg = colors.base0 }, b = { fg = colors.base02, bg = colors.base0 },
c = {fg = colors.base2, bg = colors.base02} c = { fg = colors.base2, bg = colors.base02 },
}, },
insert = { a = { fg = colors.base02, bg = colors.green, gui = 'bold' } }, insert = { a = { fg = colors.base02, bg = colors.green, gui = 'bold' } },
visual = { a = { fg = colors.base02, bg = colors.magenta, gui = 'bold' } }, visual = { a = { fg = colors.base02, bg = colors.magenta, gui = 'bold' } },
@ -33,6 +33,6 @@ return {
inactive = { inactive = {
a = { fg = colors.base1, bg = colors.base02, gui = 'bold' }, a = { fg = colors.base1, bg = colors.base02, gui = 'bold' },
b = { fg = colors.base023, bg = colors.base01 }, b = { fg = colors.base023, bg = colors.base01 },
c = {fg = colors.base1, bg = colors.base023} c = { fg = colors.base1, bg = colors.base023 },
} },
} }

View File

@ -312,7 +312,7 @@ function M.cterm2rgb(color)
local color_data = color_table[color + 1] local color_data = color_table[color + 1]
if color_data ~= nil then if color_data ~= nil then
color_data = color_data[2] color_data = color_data[2]
return string.format("#%02x%02x%02x", color_data[1], color_data[2], color_data[3]) return string.format('#%02x%02x%02x', color_data[1], color_data[2], color_data[3])
end end
end end

View File

@ -5,8 +5,12 @@ local Job = setmetatable({
return self.job_id > 0 return self.job_id > 0
end, end,
stop = function(self) stop = function(self)
if self.killed then return end if self.killed then
if self.job_id and self.job_id > 0 then vim.fn.jobstop(self.job_id) end return
end
if self.job_id and self.job_id > 0 then
vim.fn.jobstop(self.job_id)
end
self.job_id = 0 self.job_id = 0
self.killed = true self.killed = true
end, end,
@ -16,19 +20,23 @@ local Job = setmetatable({
local original_cb = self.args[name] local original_cb = self.args[name]
if original_cb then if original_cb then
self.args[name] = function(...) self.args[name] = function(...)
if not self.killed then return original_cb(...) end if not self.killed then
return original_cb(...)
end end
end end
end end
end,
}, { }, {
__call = function(self, args) __call = function(self, args)
args = vim.deepcopy(args or {}) args = vim.deepcopy(args or {})
if type(args.cmd) == 'string' then args.cmd = vim.split(args.cmd, ' ') end if type(args.cmd) == 'string' then
args.cmd = vim.split(args.cmd, ' ')
end
self.__index = self self.__index = self
local job = setmetatable({ args = args }, self) local job = setmetatable({ args = args }, self)
job:wrap_cb_alive('on_stdout') job:wrap_cb_alive 'on_stdout'
job:wrap_cb_alive('on_stderr') job:wrap_cb_alive 'on_stderr'
job:wrap_cb_alive('on_stdin') job:wrap_cb_alive 'on_stdin'
return job return job
end, end,
}) })

View File

@ -12,8 +12,7 @@ local sep = lualine_require.sep
local component_types = { local component_types = {
luaf = function(component) luaf = function(component)
return return require('lualine.components.special.function_component'):new(component)
require('lualine.components.special.function_component'):new(component)
end, end,
mod = function(component) mod = function(component)
local ok, loaded_component = pcall(require, 'lualine.components.' .. component[1]) local ok, loaded_component = pcall(require, 'lualine.components.' .. component[1])
@ -25,18 +24,17 @@ local component_types = {
end, end,
stl = function(component) stl = function(component)
local stl_expr = component[1] -- Vim's %p %l statusline elements local stl_expr = component[1] -- Vim's %p %l statusline elements
component[1] = function() return stl_expr end component[1] = function()
return return stl_expr
require('lualine.components.special.function_component'):new(component) end
return require('lualine.components.special.function_component'):new(component)
end, end,
var = function(component) var = function(component)
return return require('lualine.components.special.vim_var_component'):new(component)
require('lualine.components.special.vim_var_component'):new(component)
end, end,
['_'] = function(component) ['_'] = function(component)
return return require('lualine.components.special.eval_func_component'):new(component)
require('lualine.components.special.eval_func_component'):new(component) end,
end
} }
local function component_loader(component) local function component_loader(component)
@ -51,10 +49,13 @@ local function component_loader(component)
elseif component.type == 'vimf' or component.type == 'luae' then elseif component.type == 'vimf' or component.type == 'luae' then
return component_types['_'](component) return component_types['_'](component)
else else
modules.notice.add_notice(string.format([[ modules.notice.add_notice(string.format(
[[
### component.type ### component.type
component type '%s' isn't recognised. Check if spelling is correct.]], component.type)) component type '%s' isn't recognised. Check if spelling is correct.]],
component.type
))
end end
end end
local loaded_component = component_types.mod(component) local loaded_component = component_types.mod(component)
@ -62,7 +63,7 @@ component type '%s' isn't recognised. Check if spelling is correct.]], component
return loaded_component return loaded_component
elseif string.char(component[1]:byte(1)) == '%' then elseif string.char(component[1]:byte(1)) == '%' then
return component_types.stl(component) return component_types.stl(component)
elseif component[1]:find('[gvtwb]?o?:') == 1 then elseif component[1]:find '[gvtwb]?o?:' == 1 then
return component_types.var(component) return component_types.var(component)
else else
return component_types['_'](component) return component_types['_'](component)
@ -107,10 +108,13 @@ local function load_extensions(config)
end end
table.insert(loaded_extensions, local_extension) table.insert(loaded_extensions, local_extension)
else else
modules.notice.add_notice(string.format([[ modules.notice.add_notice(string.format(
[[
### Extensions ### Extensions
Extension named `%s` was not found . Check if spelling is correct. Extension named `%s` was not found . Check if spelling is correct.
]], extension)) ]],
extension
))
end end
elseif type(extension) == 'table' then elseif type(extension) == 'table' then
local local_extension = vim.deepcopy(extension) local local_extension = vim.deepcopy(extension)
@ -133,14 +137,14 @@ local function load_all(config)
end end
local function load_theme(theme_name) local function load_theme(theme_name)
assert(is_valid_filename(theme_name), "Invalid filename") assert(is_valid_filename(theme_name), 'Invalid filename')
local retval local retval
local path = table.concat({ 'lua', 'lualine', 'themes', theme_name }, sep) .. '.lua' local path = table.concat({ 'lua', 'lualine', 'themes', theme_name }, sep) .. '.lua'
local files = lualine_require.rtp_searcher(path) local files = lualine_require.rtp_searcher(path)
local n_files = #files local n_files = #files
if n_files == 0 then if n_files == 0 then
-- No match found -- No match found
error(path .. " Not found") error(path .. ' Not found')
elseif n_files == 1 then elseif n_files == 1 then
-- when only one is found run that and return it's return value -- when only one is found run that and return it's return value
retval = dofile(files[1]) retval = dofile(files[1])
@ -166,5 +170,5 @@ end
return { return {
load_all = load_all, load_all = load_all,
load_theme = load_theme load_theme = load_theme,
} }

View File

@ -36,7 +36,9 @@ Mode.map = {
function Mode.get_mode() function Mode.get_mode()
local mode_code = vim.api.nvim_get_mode().mode local mode_code = vim.api.nvim_get_mode().mode
if Mode.map[mode_code] == nil then return mode_code end if Mode.map[mode_code] == nil then
return mode_code
end
return Mode.map[mode_code] return Mode.map[mode_code]
end end

View File

@ -3,17 +3,21 @@ local M = {}
local notices = {} local notices = {}
function M.add_notice(notice) function M.add_notice(notice)
if type(notice) == 'string' then notice = vim.split(notice, "\n") end if type(notice) == 'string' then
notice = vim.split(notice, '\n')
end
table.insert(notices, notice) table.insert(notices, notice)
end end
function M.notice_message_startup() function M.notice_message_startup()
if #notices > 0 then if #notices > 0 then
vim.cmd('command! -nargs=0 LualineNotices lua require"lualine.utils.notices".show_notices()') vim.cmd 'command! -nargs=0 LualineNotices lua require"lualine.utils.notices".show_notices()'
vim.schedule(function() vim.schedule(function()
vim.notify( vim.notify(
"lualine: There are some issues with your config. Run :LualineNotices for details", 'lualine: There are some issues with your config. Run :LualineNotices for details',
vim.log.levels.WARN, {}) vim.log.levels.WARN,
{}
)
end) end)
end end
end end
@ -25,11 +29,10 @@ function M.show_notices()
:silent! nnoremap <silent><buffer> q <cmd>bd<cr> :silent! nnoremap <silent><buffer> q <cmd>bd<cr>
:silent! normal ggdG :silent! normal ggdG
]] ]]
local ok, _ = pcall(vim.api.nvim_buf_set_name, 0, "Lualine Notices") local ok, _ = pcall(vim.api.nvim_buf_set_name, 0, 'Lualine Notices')
if not ok then if not ok then
vim.notify("Lualine Notices is already open in another window", vim.notify('Lualine Notices is already open in another window', vim.log.levels.ERROR, {})
vim.log.levels.ERROR, {}) vim.cmd 'normal q'
vim.cmd('normal q')
return return
end end
local notice = vim.tbl_flatten(notices) local notice = vim.tbl_flatten(notices)

View File

@ -1,19 +1,17 @@
-- Copyright (c) 2020-2021 hoob3rt -- Copyright (c) 2020-2021 hoob3rt
-- MIT license, see LICENSE for more details. -- MIT license, see LICENSE for more details.
local M = {} local M = {}
local require = require'lualine_require'.require local require = require('lualine_require').require
local utils = require('lualine.utils.utils') local utils = require 'lualine.utils.utils'
local highlight = require('lualine.highlight') local highlight = require 'lualine.highlight'
-- Returns formated string for a section -- Returns formated string for a section
function M.draw_section(section, section_name, is_focused) function M.draw_section(section, section_name, is_focused)
local highlight_name = highlight.format_highlight(is_focused, local highlight_name = highlight.format_highlight(is_focused, 'lualine_' .. section_name)
'lualine_' .. section_name)
local status = {} local status = {}
for _, component in pairs(section) do for _, component in pairs(section) do
-- load components into status table -- load components into status table
if type(component) ~= 'table' or if type(component) ~= 'table' or (type(component) == 'table' and not component.component_no) then
(type(component) == 'table' and not component.component_no) then
return '' -- unknown element in section. section posibly not yet loaded return '' -- unknown element in section. section posibly not yet loaded
end end
table.insert(status, component:draw(highlight_name, is_focused)) table.insert(status, component:draw(highlight_name, is_focused))
@ -26,17 +24,23 @@ function M.draw_section(section, section_name, is_focused)
-- Check through components to see when component separator need to be removed -- Check through components to see when component separator need to be removed
for component_no = #section, 1, -1 do for component_no = #section, 1, -1 do
if #status[component_no] > 0 then first_component_no = component_no end if #status[component_no] > 0 then
first_component_no = component_no
end
-- Remove component separator with highlight for last component -- Remove component separator with highlight for last component
if not last_component_found and #status[component_no] > 0 then if not last_component_found and #status[component_no] > 0 then
last_component_found = true last_component_found = true
status[component_no] = section[component_no]:strip_separator() status[component_no] = section[component_no]:strip_separator()
if section_name < 'c' then if section_name < 'c' then
if type(section[first_component_no].options.separator) ~= 'table' and if
section[1].options.section_separators[1] ~= '' then type(section[first_component_no].options.separator) ~= 'table'
status[component_no] = string.format('%s%%S{%s}', and section[1].options.section_separators[1] ~= ''
status[component_no], section[1] then
.options.section_separators[1]) status[component_no] = string.format(
'%s%%S{%s}',
status[component_no],
section[1].options.section_separators[1]
)
end end
end end
end end
@ -46,41 +50,50 @@ function M.draw_section(section, section_name, is_focused)
status[component_no] = section[component_no]:strip_separator() status[component_no] = section[component_no]:strip_separator()
end end
-- Remove component separator when color option is used to color background -- Remove component separator when color option is used to color background
if (type(section[component_no].options.color) == 'table' and if
section[component_no].options.color.bg) or (type(section[component_no].options.color) == 'table' and section[component_no].options.color.bg)
type(section[component_no].options.color) == 'string' then or type(section[component_no].options.color) == 'string'
then
strip_next_component = true strip_next_component = true
status[component_no] = section[component_no]:strip_separator() status[component_no] = section[component_no]:strip_separator()
end end
if (section[component_no].strip_previous_separator == true) then if section[component_no].strip_previous_separator == true then
strip_next_component = true strip_next_component = true
end end
end end
local left_sparator_string = '' local left_sparator_string = ''
if section_name > 'x' and section[first_component_no] and if
type(section[first_component_no].options.separator) ~= 'table' and section_name > 'x'
section[1].options.section_separators[2] ~= '' then and section[first_component_no]
left_sparator_string = string.format('%%s{%s}', and type(section[first_component_no].options.separator) ~= 'table'
section[first_component_no].options.ls_separator or and section[1].options.section_separators[2] ~= ''
section[1].options.section_separators[2]) then
left_sparator_string = string.format(
'%%s{%s}',
section[first_component_no].options.ls_separator or section[1].options.section_separators[2]
)
end end
-- Remove empty strings from status -- Remove empty strings from status
status = utils.list_shrink(status) status = utils.list_shrink(status)
local status_str = table.concat(status) local status_str = table.concat(status)
if #status_str == 0 then return '' end if #status_str == 0 then
return ''
end
local needs_hl local needs_hl
local find_start_trans_sep_start, find_start_trans_sep_end = status_str:find('^%%s{.-}') local find_start_trans_sep_start, find_start_trans_sep_end = status_str:find '^%%s{.-}'
if find_start_trans_sep_start then if find_start_trans_sep_start then
-- the section doesn't need to be prepended with default hl when sections -- the section doesn't need to be prepended with default hl when sections
-- first component has trasitionals sep -- first component has trasitionals sep
needs_hl = status_str:find('^%%#', find_start_trans_sep_end + 1) needs_hl = status_str:find('^%%#', find_start_trans_sep_end + 1)
else needs_hl = status_str:find('^%%#') end else
needs_hl = status_str:find '^%%#'
end
if needs_hl then if needs_hl then
-- Don't prepend with old highlight when the component changes it imidiately -- Don't prepend with old highlight when the component changes it imidiately

View File

@ -5,7 +5,9 @@ local M = {}
-- Note for now only works for termguicolors scope can be bg or fg or any other -- Note for now only works for termguicolors scope can be bg or fg or any other
-- attr parameter like bold/italic/reverse -- attr parameter like bold/italic/reverse
function M.extract_highlight_colors(color_group, scope) function M.extract_highlight_colors(color_group, scope)
if vim.fn.hlexists(color_group) == 0 then return nil end if vim.fn.hlexists(color_group) == 0 then
return nil
end
local color = vim.api.nvim_get_hl_by_name(color_group, true) local color = vim.api.nvim_get_hl_by_name(color_group, true)
if color.background ~= nil then if color.background ~= nil then
color.bg = string.format('#%06x', color.background) color.bg = string.format('#%06x', color.background)
@ -15,7 +17,9 @@ function M.extract_highlight_colors(color_group, scope)
color.fg = string.format('#%06x', color.foreground) color.fg = string.format('#%06x', color.foreground)
color.foreground = nil color.foreground = nil
end end
if scope then return color[scope] end if scope then
return color[scope]
end
return color return color
end end
@ -23,22 +27,26 @@ end
function M.list_shrink(list) function M.list_shrink(list)
local new_list = {} local new_list = {}
for i = 1, #list do for i = 1, #list do
if list[i] and #list[i] > 0 then table.insert(new_list, list[i]) end if list[i] and #list[i] > 0 then
table.insert(new_list, list[i])
end
end end
return new_list return new_list
end end
-- Check if a auto command is already defined -- Check if a auto command is already defined
local function autocmd_is_defined(event, patern, command_str) local function autocmd_is_defined(event, patern, command_str)
return vim.api.nvim_exec(string.format("au lualine %s %s", return vim.api.nvim_exec(string.format('au lualine %s %s', event, patern), true):find(command_str) ~= nil
event, patern), true):find(command_str) ~= nil
end end
-- Define a auto command if it's not already defined -- Define a auto command if it's not already defined
function M.define_autocmd(event, patern, cmd) function M.define_autocmd(event, patern, cmd)
if not cmd then cmd = patern; patern = '*' end if not cmd then
cmd = patern
patern = '*'
end
if not autocmd_is_defined(event, patern, cmd) then if not autocmd_is_defined(event, patern, cmd) then
vim.cmd(string.format("autocmd lualine %s %s %s", event, patern, cmd)) vim.cmd(string.format('autocmd lualine %s %s %s', event, patern, cmd))
end end
end end

View File

@ -2,26 +2,30 @@ local M = {}
M.sep = package.config:sub(1, 1) M.sep = package.config:sub(1, 1)
local source = debug.getinfo(1, "S").source local source = debug.getinfo(1, 'S').source
if source:sub(1, 1) == '@' then if source:sub(1, 1) == '@' then
local base_start = source:find(table.concat({ 'lualine.nvim', 'lua', 'lualine_require.lua' }, M.sep)) local base_start = source:find(table.concat({ 'lualine.nvim', 'lua', 'lualine_require.lua' }, M.sep))
if base_start then if base_start then
source = source:sub(2, base_start + 12 + 1 + 3) -- #lualine.nvim = 12 , #lua = 3. source = source:sub(2, base_start + 12 + 1 + 3) -- #lualine.nvim = 12 , #lua = 3.
if source then M.plugin_dir = source end if source then
M.plugin_dir = source
end
end end
end end
function M.is_valid_filename(name) function M.is_valid_filename(name)
local invalid_chars="[^a-zA-Z0-9_. -]" local invalid_chars = '[^a-zA-Z0-9_. -]'
return name:find(invalid_chars) == nil return name:find(invalid_chars) == nil
end end
function M.require(module) function M.require(module)
if package.loaded[module] then return package.loaded[module] end if package.loaded[module] then
return package.loaded[module]
end
local pattern = module:gsub('%.', M.sep) .. '.lua' local pattern = module:gsub('%.', M.sep) .. '.lua'
if M.plugin_dir then if M.plugin_dir then
local path = M.plugin_dir .. pattern local path = M.plugin_dir .. pattern
assert(M.is_valid_filename(module), "Invalid filename") assert(M.is_valid_filename(module), 'Invalid filename')
if vim.loop.fs_stat(path) then if vim.loop.fs_stat(path) then
local mod_result = dofile(path) local mod_result = dofile(path)
package.loaded[module] = mod_result package.loaded[module] = mod_result
@ -41,11 +45,13 @@ end
function M.rtp_searcher(file, once) function M.rtp_searcher(file, once)
local ret = {} local ret = {}
for dir in vim.gsplit(vim.api.nvim_get_option('rtp'), ',') do for dir in vim.gsplit(vim.api.nvim_get_option 'rtp', ',') do
local path = dir .. M.sep .. file local path = dir .. M.sep .. file
if vim.loop.fs_stat(path) then if vim.loop.fs_stat(path) then
ret[#ret + 1] = path ret[#ret + 1] = path
if once then break end if once then
break
end
end end
end end
return ret return ret
@ -55,13 +61,17 @@ function M.lazy_require(modules)
return setmetatable({}, { return setmetatable({}, {
__index = function(self, key) __index = function(self, key)
local loaded = rawget(self, key) local loaded = rawget(self, key)
if loaded ~= nil then return loaded end if loaded ~= nil then
return loaded
end
local module_location = modules[key] local module_location = modules[key]
if module_location == nil then return nil end if module_location == nil then
return nil
end
local module = M.require(module_location) local module = M.require(module_location)
rawset(self, key, module) rawset(self, key, module)
return module return module
end end,
}) })
end end

View File

@ -3,32 +3,54 @@ local eq = assert.are.same
local M = {} local M = {}
M.meths = setmetatable({}, { M.meths = setmetatable({}, {
__index = function(_, key) return vim.api['nvim_' .. key] end __index = function(_, key)
return vim.api['nvim_' .. key]
end,
}) })
-- Checks ouput of a component -- Checks ouput of a component
M.assert_component = function(component, opts, result) M.assert_component = function(component, opts, result)
-- for testing global options -- for testing global options
if component == nil then component = 'special.function_component' end if component == nil then
component = 'special.function_component'
end
local comp = require('lualine.components.' .. component):new(opts) local comp = require('lualine.components.' .. component):new(opts)
eq(result, comp:draw(opts.hl)) eq(result, comp:draw(opts.hl))
end end
-- sets defaults for component options -- sets defaults for component options
M.build_component_opts = function(opts) M.build_component_opts = function(opts)
if not opts then opts = {} end if not opts then
if opts[1] == nil then opts[1] = function() return 'test' end end opts = {}
if not opts.self then opts.self = {section = 'lualine_c'} end end
if not opts.theme then opts.theme = 'gruvbox' end if opts[1] == nil then
if not opts.hl then opts.hl = '' end opts[1] = function()
if opts.icons_enabled == nil then opts.icons_enabled = true end return 'test'
end
end
if not opts.self then
opts.self = { section = 'lualine_c' }
end
if not opts.theme then
opts.theme = 'gruvbox'
end
if not opts.hl then
opts.hl = ''
end
if opts.icons_enabled == nil then
opts.icons_enabled = true
end
if not opts.component_separators then if not opts.component_separators then
opts.component_separators = { '', '' } opts.component_separators = { '', '' }
end end
if not opts.section_separators then opts.section_separators = {'', ''} end if not opts.section_separators then
opts.section_separators = { '', '' }
end
return opts return opts
end end
M.P = function(t) print(vim.inspect(t)) end M.P = function(t)
print(vim.inspect(t))
end
return M return M

View File

@ -1,5 +1,8 @@
-- load lualine and plenary -- load lualine and plenary
vim.api.nvim_exec([[ vim.api.nvim_exec(
[[
set rtp+=. set rtp+=.
set rtp+=../plenary.nvim set rtp+=../plenary.nvim
]], false) ]],
false
)

View File

@ -9,217 +9,216 @@ local stub = require 'luassert.stub'
describe('Component:', function() describe('Component:', function()
it('can select separators', function() it('can select separators', function()
local opts = build_component_opts() local opts = build_component_opts()
local comp = require('lualine.components.special.function_component'):new( local comp = require('lualine.components.special.function_component'):new(opts)
opts)
-- correct for lualine_c -- correct for lualine_c
eq('', comp.options.separator) eq('', comp.options.separator)
local opts2 = build_component_opts({self = {section = 'lualine_y'}}) local opts2 = build_component_opts { self = { section = 'lualine_y' } }
local comp2 = require('lualine.components.special.function_component'):new( local comp2 = require('lualine.components.special.function_component'):new(opts2)
opts2)
-- correct for lualine_u -- correct for lualine_u
eq('', comp2.options.separator) eq('', comp2.options.separator)
end) end)
it('can provide unique identifier', function() it('can provide unique identifier', function()
local opts1 = build_component_opts() local opts1 = build_component_opts()
local comp1 = require('lualine.components.special.function_component'):new( local comp1 = require('lualine.components.special.function_component'):new(opts1)
opts1)
local opts2 = build_component_opts() local opts2 = build_component_opts()
local comp2 = require('lualine.components.special.function_component'):new( local comp2 = require('lualine.components.special.function_component'):new(opts2)
opts2)
neq(comp1.component_no, comp2.component_no) neq(comp1.component_no, comp2.component_no)
end) end)
it('create option highlights', function() it('create option highlights', function()
local color = { fg = '#224532', bg = '#892345' } local color = { fg = '#224532', bg = '#892345' }
local opts1 = build_component_opts({color = color}) local opts1 = build_component_opts { color = color }
local hl = require 'lualine.highlight' local hl = require 'lualine.highlight'
stub(hl, 'create_component_highlight_group') stub(hl, 'create_component_highlight_group')
hl.create_component_highlight_group.returns('MyCompHl') hl.create_component_highlight_group.returns 'MyCompHl'
local comp1 = require('lualine.components.special.function_component'):new( local comp1 = require('lualine.components.special.function_component'):new(opts1)
opts1)
eq('MyCompHl', comp1.options.color_highlight) eq('MyCompHl', comp1.options.color_highlight)
-- color highlight wan't in options when create_comp_hl was -- color highlight wan't in options when create_comp_hl was
-- called so remove it before assert -- called so remove it before assert
comp1.options.color_highlight = nil comp1.options.color_highlight = nil
assert.stub(hl.create_component_highlight_group).was_called_with(color, assert.stub(hl.create_component_highlight_group).was_called_with(color, comp1.options.component_name, comp1.options)
comp1.options
.component_name,
comp1.options)
hl.create_component_highlight_group:revert() hl.create_component_highlight_group:revert()
color = 'MyHl' color = 'MyHl'
local opts2 = build_component_opts({color = color}) local opts2 = build_component_opts { color = color }
stub(hl, 'create_component_highlight_group') stub(hl, 'create_component_highlight_group')
hl.create_component_highlight_group.returns('MyCompLinkedHl') hl.create_component_highlight_group.returns 'MyCompLinkedHl'
local comp2 = require('lualine.components.special.function_component'):new( local comp2 = require('lualine.components.special.function_component'):new(opts2)
opts2)
eq('MyCompLinkedHl', comp2.options.color_highlight) eq('MyCompLinkedHl', comp2.options.color_highlight)
-- color highlight wan't in options when create_comp_hl was -- color highlight wan't in options when create_comp_hl was
-- called so remove it before assert -- called so remove it before assert
comp2.options.color_highlight = nil comp2.options.color_highlight = nil
assert.stub(hl.create_component_highlight_group).was_called_with(color, assert.stub(hl.create_component_highlight_group).was_called_with(color, comp2.options.component_name, comp2.options)
comp2.options
.component_name,
comp2.options)
hl.create_component_highlight_group:revert() hl.create_component_highlight_group:revert()
end) end)
it('can draw', function() it('can draw', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
assert_component(nil, opts, 'test') assert_component(nil, opts, 'test')
end) end)
it('can apply separators', function() it('can apply separators', function()
local opts = build_component_opts({padding = 0}) local opts = build_component_opts { padding = 0 }
assert_component(nil, opts, 'test') assert_component(nil, opts, 'test')
end) end)
it('can apply default highlight', function() it('can apply default highlight', function()
local opts = build_component_opts({padding = 0, hl = '%#My_highlight#'}) local opts = build_component_opts { padding = 0, hl = '%#My_highlight#' }
assert_component(nil, opts, '%#My_highlight#test') assert_component(nil, opts, '%#My_highlight#test')
opts = build_component_opts({function() return "%#Custom_hl#test" end, opts = build_component_opts {
padding = 0, hl = '%#My_highlight#'}) function()
return '%#Custom_hl#test'
end,
padding = 0,
hl = '%#My_highlight#',
}
assert_component(nil, opts, '%#Custom_hl#test%#My_highlight#') assert_component(nil, opts, '%#Custom_hl#test%#My_highlight#')
opts = build_component_opts({function() return "in middle%#Custom_hl#test" end, opts = build_component_opts {
padding = 0, hl = '%#My_highlight#'}) function()
return 'in middle%#Custom_hl#test'
end,
padding = 0,
hl = '%#My_highlight#',
}
assert_component(nil, opts, '%#My_highlight#in middle%#Custom_hl#test%#My_highlight#') assert_component(nil, opts, '%#My_highlight#in middle%#Custom_hl#test%#My_highlight#')
end) end)
describe('Global options:', function() describe('Global options:', function()
it('upper', function() it('upper', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
upper = true upper = true,
}) }
assert_component(nil, opts, 'TEST') assert_component(nil, opts, 'TEST')
end) end)
it('lower', function() it('lower', function()
local opts = build_component_opts({ local opts = build_component_opts {
function() return 'TeSt' end, function()
return 'TeSt'
end,
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
lower = true lower = true,
}) }
assert_component(nil, opts, 'test') assert_component(nil, opts, 'test')
end) end)
it('left_padding', function() it('left_padding', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
left_padding = 5 left_padding = 5,
}) }
assert_component(nil, opts, ' test') assert_component(nil, opts, ' test')
end) end)
it('right_padding', function() it('right_padding', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
right_padding = 5 right_padding = 5,
}) }
assert_component(nil, opts, 'test ') assert_component(nil, opts, 'test ')
end) end)
it('padding', function() it('padding', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 5 padding = 5,
}) }
assert_component(nil, opts, ' test ') assert_component(nil, opts, ' test ')
end) end)
it('icon', function() it('icon', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
icon = '0' icon = '0',
}) }
assert_component(nil, opts, '0 test') assert_component(nil, opts, '0 test')
end) end)
it('icons_enabled', function() it('icons_enabled', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
icons_enabled = true, icons_enabled = true,
icon = '0' icon = '0',
}) }
assert_component(nil, opts, '0 test') assert_component(nil, opts, '0 test')
local opts2 = build_component_opts( local opts2 = build_component_opts {
{
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
icons_enabled = false, icons_enabled = false,
icon = '0' icon = '0',
}) }
assert_component(nil, opts2, 'test') assert_component(nil, opts2, 'test')
end) end)
it('separator', function() it('separator', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
separator = '|' separator = '|',
}) }
assert_component(nil, opts, 'test|') assert_component(nil, opts, 'test|')
end) end)
it('format', function() it('format', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
format = function(data) format = function(data)
return data:sub(1, 1):upper() .. data:sub(2, #data) return data:sub(1, 1):upper() .. data:sub(2, #data)
end end,
}) }
assert_component(nil, opts, 'Test') assert_component(nil, opts, 'Test')
end) end)
it('condition', function() it('condition', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
condition = function() return true end condition = function()
}) return true
end,
}
assert_component(nil, opts, 'test') assert_component(nil, opts, 'test')
local opts2 = build_component_opts( local opts2 = build_component_opts {
{
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
condition = function() return false end condition = function()
}) return false
end,
}
assert_component(nil, opts2, '') assert_component(nil, opts2, '')
end) end)
it('color', function() it('color', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
color = 'MyHl' color = 'MyHl',
}) }
local comp = require('lualine.components.special.function_component'):new(opts) local comp = require('lualine.components.special.function_component'):new(opts)
local custom_link_hl_name = 'lualine_' .. comp.options.component_name .. '_no_mode' local custom_link_hl_name = 'lualine_' .. comp.options.component_name .. '_no_mode'
eq('%#' .. custom_link_hl_name .. '#test', comp:draw(opts.hl)) eq('%#' .. custom_link_hl_name .. '#test', comp:draw(opts.hl))
local opts2 = build_component_opts( local opts2 = build_component_opts {
{
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
color = {bg = '#230055', fg = '#223344'} color = { bg = '#230055', fg = '#223344' },
}) }
local hl = require 'lualine.highlight' local hl = require 'lualine.highlight'
stub(hl, 'component_format_highlight') stub(hl, 'component_format_highlight')
hl.component_format_highlight.returns('%#MyCompHl#') hl.component_format_highlight.returns '%#MyCompHl#'
local comp2 = local comp2 = require('lualine.components.special.function_component'):new(opts2)
require('lualine.components.special.function_component'):new(opts2)
assert_component(nil, opts2, '%#MyCompHl#test') assert_component(nil, opts2, '%#MyCompHl#test')
assert.stub(hl.component_format_highlight).was_called_with( assert.stub(hl.component_format_highlight).was_called_with(comp2.options.color_highlight)
comp2.options.color_highlight)
hl.component_format_highlight:revert() hl.component_format_highlight:revert()
end) end)
end) end)
@ -227,20 +226,20 @@ end)
describe('Encoding component', function() describe('Encoding component', function()
it('works', function() it('works', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
assert_component('encoding', opts, '%{strlen(&fenc)?&fenc:&enc}') assert_component('encoding', opts, '%{strlen(&fenc)?&fenc:&enc}')
end) end)
end) end)
describe('Fileformat component', function() describe('Fileformat component', function()
it('works with icons', function() it('works with icons', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
local fmt = vim.bo.fileformat local fmt = vim.bo.fileformat
vim.bo.fileformat = 'unix' vim.bo.fileformat = 'unix'
assert_component('fileformat', opts, '') assert_component('fileformat', opts, '')
@ -251,11 +250,11 @@ describe('Fileformat component', function()
vim.bo.fileformat = fmt vim.bo.fileformat = fmt
end) end)
it('works without icons', function() it('works without icons', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
icons_enabled = false icons_enabled = false,
}) }
assert_component('fileformat', opts, vim.bo.fileformat) assert_component('fileformat', opts, vim.bo.fileformat)
end) end)
end) end)
@ -273,10 +272,10 @@ describe('Filetype component', function()
end) end)
it('does not add icon when library unavailable', function() it('does not add icon when library unavailable', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
assert_component('filetype', opts, 'lua') assert_component('filetype', opts, 'lua')
end) end)
@ -284,49 +283,47 @@ describe('Filetype component', function()
package.loaded['nvim-web-devicons'] = { package.loaded['nvim-web-devicons'] = {
get_icon = function() get_icon = function()
return '*', 'test_highlight_group' return '*', 'test_highlight_group'
end end,
} }
local hl = require 'lualine.highlight' local hl = require 'lualine.highlight'
local utils = require 'lualine.utils.utils' local utils = require 'lualine.utils.utils'
stub(hl, 'create_component_highlight_group') stub(hl, 'create_component_highlight_group')
stub(utils, 'extract_highlight_colors') stub(utils, 'extract_highlight_colors')
hl.create_component_highlight_group.returns('MyCompHl') hl.create_component_highlight_group.returns 'MyCompHl'
utils.extract_highlight_colors.returns('#000') utils.extract_highlight_colors.returns '#000'
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
colored = true, colored = true,
disable_text = false, disable_text = false,
}) }
assert_component('filetype', opts, '%#MyCompHl_normal#*%#lualine_c_normal# lua') assert_component('filetype', opts, '%#MyCompHl_normal#*%#lualine_c_normal# lua')
assert.stub(utils.extract_highlight_colors).was_called_with('test_highlight_group', 'fg') assert.stub(utils.extract_highlight_colors).was_called_with('test_highlight_group', 'fg')
assert.stub(hl.create_component_highlight_group).was_called_with( assert.stub(hl.create_component_highlight_group).was_called_with({ fg = '#000' }, 'test_highlight_group', opts)
{fg = '#000'}, 'test_highlight_group', opts
)
hl.create_component_highlight_group:revert() hl.create_component_highlight_group:revert()
utils.extract_highlight_colors:revert() utils.extract_highlight_colors:revert()
package.loaded['nvim-web-devicons'] = nil package.loaded['nvim-web-devicons'] = nil
end) end)
it('Doesn\'t color when colored is false', function() it("Doesn't color when colored is false", function()
package.loaded['nvim-web-devicons'] = { package.loaded['nvim-web-devicons'] = {
get_icon = function() get_icon = function()
return '*', 'test_highlight_group' return '*', 'test_highlight_group'
end end,
} }
local hl = require 'lualine.highlight' local hl = require 'lualine.highlight'
local utils = require 'lualine.utils.utils' local utils = require 'lualine.utils.utils'
stub(hl, 'create_component_highlight_group') stub(hl, 'create_component_highlight_group')
stub(utils, 'extract_highlight_colors') stub(utils, 'extract_highlight_colors')
hl.create_component_highlight_group.returns('MyCompHl') hl.create_component_highlight_group.returns 'MyCompHl'
utils.extract_highlight_colors.returns('#000') utils.extract_highlight_colors.returns '#000'
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
colored = false, colored = false,
}) }
assert_component('filetype', opts, '* lua') assert_component('filetype', opts, '* lua')
hl.create_component_highlight_group:revert() hl.create_component_highlight_group:revert()
utils.extract_highlight_colors:revert() utils.extract_highlight_colors:revert()
@ -337,15 +334,15 @@ describe('Filetype component', function()
package.loaded['nvim-web-devicons'] = { package.loaded['nvim-web-devicons'] = {
get_icon = function() get_icon = function()
return '*', 'test_highlight_group' return '*', 'test_highlight_group'
end end,
} }
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0, padding = 0,
colored = false, colored = false,
disable_text = true, disable_text = true,
}) }
assert_component('filetype', opts, '*') assert_component('filetype', opts, '*')
package.loaded['nvim-web-devicons'] = nil package.loaded['nvim-web-devicons'] = nil
end) end)
@ -354,11 +351,11 @@ end)
describe('Hostname component', function() describe('Hostname component', function()
it('works', function() it('works', function()
stub(vim.loop, 'os_gethostname') stub(vim.loop, 'os_gethostname')
vim.loop.os_gethostname.returns('localhost') vim.loop.os_gethostname.returns 'localhost'
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
assert_component('hostname', opts, 'localhost') assert_component('hostname', opts, 'localhost')
vim.loop.os_gethostname:revert() vim.loop.os_gethostname:revert()
end) end)
@ -366,20 +363,20 @@ end)
describe('Location component', function() describe('Location component', function()
it('works', function() it('works', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
assert_component('location', opts, '%3l:%-2c') assert_component('location', opts, '%3l:%-2c')
end) end)
end) end)
describe('Progress component', function() describe('Progress component', function()
it('works', function() it('works', function()
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
assert_component('progress', opts, '%3P') assert_component('progress', opts, '%3P')
end) end)
end) end)
@ -387,11 +384,11 @@ end)
describe('Mode component', function() describe('Mode component', function()
it('works', function() it('works', function()
stub(vim.api, 'nvim_get_mode') stub(vim.api, 'nvim_get_mode')
vim.api.nvim_get_mode.returns({mode = 'n', blocking = false}) vim.api.nvim_get_mode.returns { mode = 'n', blocking = false }
local opts = build_component_opts({ local opts = build_component_opts {
component_separators = { '', '' }, component_separators = { '', '' },
padding = 0 padding = 0,
}) }
assert_component('mode', opts, 'NORMAL') assert_component('mode', opts, 'NORMAL')
vim.api.nvim_get_mode:revert() vim.api.nvim_get_mode:revert()
end) end)

View File

@ -6,7 +6,7 @@ describe('config parsing', function()
describe('options', function() describe('options', function()
describe('icons_enabled', function() describe('icons_enabled', function()
it('default', function() it('default', function()
local config = config_module.apply_configuration({}) local config = config_module.apply_configuration {}
eq(config.options.icons_enabled, true) eq(config.options.icons_enabled, true)
end) end)
it('custom', function() it('custom', function()
@ -18,7 +18,7 @@ describe('config parsing', function()
describe('theme', function() describe('theme', function()
it('default', function() it('default', function()
local config = config_module.apply_configuration({}) local config = config_module.apply_configuration {}
eq(config.options.theme, 'auto') eq(config.options.theme, 'auto')
end) end)
it('custom', function() it('custom', function()
@ -33,7 +33,7 @@ describe('config parsing', function()
describe('separators', function() describe('separators', function()
it('default', function() it('default', function()
local config = config_module.apply_configuration({}) local config = config_module.apply_configuration {}
eq(config.options.component_separators, { '', '' }) eq(config.options.component_separators, { '', '' })
eq(config.options.section_separators, { '', '' }) eq(config.options.section_separators, { '', '' })
end) end)
@ -41,8 +41,8 @@ describe('config parsing', function()
local config = { local config = {
options = { options = {
component_separators = { 'a', 'b' }, component_separators = { 'a', 'b' },
section_separators = {'c', 'd'} section_separators = { 'c', 'd' },
} },
} }
config = config_module.apply_configuration(config) config = config_module.apply_configuration(config)
eq(config.options.component_separators, { 'a', 'b' }) eq(config.options.component_separators, { 'a', 'b' })
@ -52,7 +52,7 @@ describe('config parsing', function()
describe('single separator', function() describe('single separator', function()
it('string', function() it('string', function()
local config = { local config = {
options = {component_separators = 'a', section_separators = 'b'} options = { component_separators = 'a', section_separators = 'b' },
} }
config = config_module.apply_configuration(config) config = config_module.apply_configuration(config)
eq(config.options.component_separators, { 'a', 'a' }) eq(config.options.component_separators, { 'a', 'a' })
@ -60,7 +60,7 @@ describe('config parsing', function()
end) end)
it('table', function() it('table', function()
local config = { local config = {
options = {component_separators = {'a'}, section_separators = {'b'}} options = { component_separators = { 'a' }, section_separators = { 'b' } },
} }
config = config_module.apply_configuration(config) config = config_module.apply_configuration(config)
eq(config.options.component_separators, { 'a', 'a' }) eq(config.options.component_separators, { 'a', 'a' })
@ -69,7 +69,7 @@ describe('config parsing', function()
end) end)
it('no seprarators', function() it('no seprarators', function()
local config = { local config = {
options = {component_separators = {}, section_separators = {}} options = { component_separators = {}, section_separators = {} },
} }
config = config_module.apply_configuration(config) config = config_module.apply_configuration(config)
eq(config.options.component_separators, {}) eq(config.options.component_separators, {})
@ -79,7 +79,7 @@ describe('config parsing', function()
describe('disabled filetypes', function() describe('disabled filetypes', function()
it('default', function() it('default', function()
local config = config_module.apply_configuration({}) local config = config_module.apply_configuration {}
eq(config.options.disabled_filetypes, {}) eq(config.options.disabled_filetypes, {})
end) end)
it('custom', function() it('custom', function()
@ -109,12 +109,11 @@ describe('config parsing', function()
config = config_module.apply_configuration(config) config = config_module.apply_configuration(config)
local lualine_default_sections = { local lualine_default_sections = {
lualine_a = { 'mode' }, lualine_a = { 'mode' },
lualine_b = {'branch', 'diff', lualine_b = { 'branch', 'diff', { 'diagnostics', sources = { 'nvim_lsp', 'coc' } } },
{'diagnostics', sources={'nvim_lsp', 'coc'}}},
lualine_c = { 'filename' }, lualine_c = { 'filename' },
lualine_x = { 'encoding', 'fileformat', 'filetype' }, lualine_x = { 'encoding', 'fileformat', 'filetype' },
lualine_y = { 'progress' }, lualine_y = { 'progress' },
lualine_z = {'location'} lualine_z = { 'location' },
} }
eq(config.sections, lualine_default_sections) eq(config.sections, lualine_default_sections)
end) end)
@ -123,7 +122,7 @@ describe('config parsing', function()
lualine_a = { { 'mode', lower = true } }, lualine_a = { { 'mode', lower = true } },
lualine_b = { 'branch', { 'branch', lower = true } }, lualine_b = { 'branch', { 'branch', lower = true } },
lualine_c = nil, lualine_c = nil,
lualine_x = {} lualine_x = {},
} }
local expected_sections = { local expected_sections = {
lualine_a = { { 'mode', lower = true } }, lualine_a = { { 'mode', lower = true } },
@ -131,7 +130,7 @@ describe('config parsing', function()
lualine_c = { 'filename' }, lualine_c = { 'filename' },
lualine_x = {}, lualine_x = {},
lualine_y = { 'progress' }, lualine_y = { 'progress' },
lualine_z = {'location'} lualine_z = { 'location' },
} }
local config = { sections = custom_sections } local config = { sections = custom_sections }
config = config_module.apply_configuration(config) config = config_module.apply_configuration(config)
@ -152,12 +151,12 @@ describe('config parsing', function()
lualine_a = { { 'mode', lower = true } }, lualine_a = { { 'mode', lower = true } },
lualine_b = { 'branch', { 'branch', lower = true } }, lualine_b = { 'branch', { 'branch', lower = true } },
lualine_c = nil, lualine_c = nil,
lualine_x = {} lualine_x = {},
} }
local expected_sections = { local expected_sections = {
lualine_a = { { 'mode', lower = true } }, lualine_a = { { 'mode', lower = true } },
lualine_b = { 'branch', { 'branch', lower = true } }, lualine_b = { 'branch', { 'branch', lower = true } },
lualine_x = {} lualine_x = {},
} }
local config = { tabline = custom_sections } local config = { tabline = custom_sections }
config = config_module.apply_configuration(config) config = config_module.apply_configuration(config)

View File

@ -4,17 +4,16 @@ local eq = assert.are.same
local build_component_opts = helpers.build_component_opts local build_component_opts = helpers.build_component_opts
describe('Utils', function() describe('Utils', function()
local utils = require('lualine.utils.utils') local utils = require 'lualine.utils.utils'
it('can retrive highlight groups', function() it('can retrive highlight groups', function()
local hl2 = { fg = '#aabbcc', bg = '#889977', reverse = true } local hl2 = { fg = '#aabbcc', bg = '#889977', reverse = true }
-- handles non existing hl groups -- handles non existing hl groups
eq(utils.extract_highlight_colors('hl2'), nil) eq(utils.extract_highlight_colors 'hl2', nil)
-- create highlight -- create highlight
vim.cmd( vim.cmd(string.format('hi hl2 guifg=%s guibg=%s gui=reverse', hl2.fg, hl2.bg))
string.format('hi hl2 guifg=%s guibg=%s gui=reverse', hl2.fg, hl2.bg))
-- Can retrive entire highlight table -- Can retrive entire highlight table
eq(utils.extract_highlight_colors('hl2'), hl2) eq(utils.extract_highlight_colors 'hl2', hl2)
-- Can retrive specific parts of highlight -- Can retrive specific parts of highlight
eq(utils.extract_highlight_colors('hl2', 'fg'), hl2.fg) eq(utils.extract_highlight_colors('hl2', 'fg'), hl2.fg)
-- clear hl2 -- clear hl2
@ -23,7 +22,18 @@ describe('Utils', function()
it('can shrink list with holes', function() it('can shrink list with holes', function()
local list_with_holes = { local list_with_holes = {
'2', '4', '6', nil, '43', nil, '2', '', 'a', '', 'b', ' ' '2',
'4',
'6',
nil,
'43',
nil,
'2',
'',
'a',
'',
'b',
' ',
} }
local list_without_holes = { '2', '4', '6', '43', '2', 'a', 'b', ' ' } local list_without_holes = { '2', '4', '6', '43', '2', 'a', 'b', ' ' }
eq(utils.list_shrink(list_with_holes), list_without_holes) eq(utils.list_shrink(list_with_holes), list_without_holes)
@ -44,57 +54,52 @@ end)
describe('Section genarator', function() describe('Section genarator', function()
local sec = require 'lualine.utils.section' local sec = require 'lualine.utils.section'
it('can draw', function() it('can draw', function()
local opts = build_component_opts({section_separators = {'', ''}}) local opts = build_component_opts { section_separators = { '', '' } }
local section = { local section = {
require('lualine.components.special.function_component'):new(opts), require('lualine.components.special.function_component'):new(opts),
require('lualine.components.special.function_component'):new(opts) require('lualine.components.special.function_component'):new(opts),
} }
eq( '%#lualine_MySection_normal# test %#lualine_MySection_normal# test ', eq('%#lualine_MySection_normal# test %#lualine_MySection_normal# test ', sec.draw_section(section, 'MySection'))
sec.draw_section(section, 'MySection'))
end) end)
it('can remove separators from component with custom colors', function() it('can remove separators from component with custom colors', function()
local opts = build_component_opts({section_separators = {'', ''}}) local opts = build_component_opts { section_separators = { '', '' } }
local opts_colored = build_component_opts({color = 'MyColor'}) local opts_colored = build_component_opts { color = 'MyColor' }
local opts_colored2 = build_component_opts( local opts_colored2 = build_component_opts {
{
color = { bg = '#223344' }, color = { bg = '#223344' },
section_separators = {'', ''} section_separators = { '', '' },
}) }
local opts_colored3 = build_component_opts( local opts_colored3 = build_component_opts {
{
color = { fg = '#223344' }, color = { fg = '#223344' },
section_separators = {'', ''} section_separators = { '', '' },
}) }
require'lualine.highlight'.create_highlight_groups( require('lualine.highlight').create_highlight_groups(require 'lualine.themes.gruvbox')
require 'lualine.themes.gruvbox')
local section = { local section = {
require('lualine.components.special.function_component'):new(opts), require('lualine.components.special.function_component'):new(opts),
require('lualine.components.special.function_component'):new(opts_colored), require('lualine.components.special.function_component'):new(opts_colored),
require('lualine.components.special.function_component'):new(opts) require('lualine.components.special.function_component'):new(opts),
} }
local highlight_name2 = 'lualine_' .. section[2].options.component_name .. '_no_mode' local highlight_name2 = 'lualine_' .. section[2].options.component_name .. '_no_mode'
-- Removes separator on string color -- Removes separator on string color
eq( '%#lualine_MySection_normal# test %#' ..highlight_name2..'#' eq(
.. ' test %#lualine_MySection_normal# test ', '%#lualine_MySection_normal# test %#' .. highlight_name2 .. '#' .. ' test %#lualine_MySection_normal# test ',
sec.draw_section(section, 'MySection')) sec.draw_section(section, 'MySection')
section[2] = )
require('lua.lualine.components.special.function_component'):new( section[2] = require('lua.lualine.components.special.function_component'):new(opts_colored2)
opts_colored2) local highlight_name = '%#lualine_c_' .. section[2].options.component_name .. '_normal#'
local highlight_name =
'%#lualine_c_' .. section[2].options.component_name .. '_normal#'
-- Removes separator on color with bg -- Removes separator on color with bg
eq('%#lualine_MySection_normal# test ' .. highlight_name .. eq(
' test %#lualine_MySection_normal# test ', '%#lualine_MySection_normal# test ' .. highlight_name .. ' test %#lualine_MySection_normal# test ',
sec.draw_section(section, 'MySection')) sec.draw_section(section, 'MySection')
section[2] = )
require('lua.lualine.components.special.function_component'):new( section[2] = require('lua.lualine.components.special.function_component'):new(opts_colored3)
opts_colored3) highlight_name2 = '%#lualine_c_' .. section[2].options.component_name .. '_normal#'
highlight_name2 =
'%#lualine_c_' .. section[2].options.component_name .. '_normal#'
-- Doesn't remove separator on color without bg -- Doesn't remove separator on color without bg
eq('%#lualine_MySection_normal# test ' .. highlight_name2 .. eq(
' test %#lualine_MySection_normal#%#lualine_MySection_normal# test ', '%#lualine_MySection_normal# test '
sec.draw_section(section, 'MySection')) .. highlight_name2
.. ' test %#lualine_MySection_normal#%#lualine_MySection_normal# test ',
sec.draw_section(section, 'MySection')
)
end) end)
end) end)