Compare commits

..

No commits in common. "e7ae1ec1dae226caae513b09216cb98a5fffc3a5" and "2dc45497c284e1fc65bacffb88a7cb3975383761" have entirely different histories.

8 changed files with 26 additions and 121 deletions

View file

@ -3,4 +3,3 @@ require("core.keymaps")
require("core.autocmds")
require('core.package_manager')
require('core.theme')
require('winbar')

View file

@ -1,6 +1,5 @@
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background="hard"
vim.g.gruvbox_material_foreground="original"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background="dark"
vim.cmd('colorscheme gruvbox-material')

View file

@ -47,7 +47,3 @@ vim.opt.signcolumn = "yes"
vim.opt.autoread = true
-- disable swapfile
vim.opt.swapfile = false
-- disable statusline
vim.o.laststatus = 1
-- border on floating windows
vim.o.winborder = nil

View file

@ -49,29 +49,6 @@ return {
local fzflua = require("fzf-lua")
local conform = require("conform")
local function jumpWithVirtLineDiags(jumpCount)
pcall(vim.api.nvim_del_augroup_by_name, "jumpWithVirtLineDiags") -- prevent autocmd for repeated jumps
vim.diagnostic.jump { count = jumpCount }
local initialVirtTextConf = vim.diagnostic.config().virtual_text
vim.diagnostic.config {
virtual_text = false,
virtual_lines = { current_line = true },
}
vim.defer_fn(function() -- deferred to not trigger by jump itself
vim.api.nvim_create_autocmd("CursorMoved", {
desc = "User(once): Reset diagnostics virtual lines",
once = true,
group = vim.api.nvim_create_augroup("jumpWithVirtLineDiags", {}),
callback = function()
vim.diagnostic.config { virtual_lines = false, virtual_text = initialVirtTextConf }
end,
})
end, 1)
end
local rename_func = function()
return ":IncRename " .. vim.fn.expand("<cword>")
end
@ -89,8 +66,8 @@ return {
vim.keymap.set("n", "<space>D", vim.lsp.buf.type_definition, bufopts)
vim.keymap.set("n", "<space>rn", rename_func, bufopts_expr)
vim.keymap.set({ "n", "v" }, "<space>ca", vim.lsp.buf.code_action, bufopts)
vim.keymap.set("n", "<space>ge", function() jumpWithVirtLineDiags(1) end, bufopts)
vim.keymap.set("n", "<space>gE", function() jumpWithVirtLineDiags(-1) end, bufopts)
vim.keymap.set("n", "<space>ge", vim.diagnostic.goto_next, bufopts)
vim.keymap.set("n", "<space>gE", vim.diagnostic.goto_prev, bufopts)
vim.keymap.set("n", "<space>fo", function() conform.format({ lsp_fallback = true }) end, bufopts)
end,
})

View file

@ -50,7 +50,6 @@ return {
{
"afonsofrancof/worktrees.nvim",
dev = true,
event = "VeryLazy",
opts = {
mappings = {
create = "<leader>wtc",

View file

@ -0,0 +1,24 @@
return {
{
'nvim-lualine/lualine.nvim',
dependencies = { 'nvim-tree/nvim-web-devicons' },
opts = {
sections = {
lualine_a = { 'mode' },
lualine_b = { 'branch', 'diff', 'diagnostics' },
lualine_c = { { 'filename', path = 1 } },
lualine_x = { 'filetype' },
lualine_y = { 'progress' },
lualine_z = { 'location' }
},
inactive_sections = {
lualine_a = {},
lualine_b = {},
lualine_c = { 'filename' },
lualine_x = { 'location' },
lualine_y = {},
lualine_z = {}
},
}
}
}

View file

@ -1,81 +0,0 @@
local M = {}
local icons = require("mini.icons")
--- Window bar that shows the current file path (in a fancy way).
---@return string
function M.render()
-- Get the path and expand variables.
local path = vim.fs.normalize(vim.fn.expand '%:p' --[[@as string]])
-- No special styling for diff views.
if vim.startswith(path, 'diffview') then
return string.format('%%#Winbar#%s', path)
end
-- Replace slashes by arrows.
local separator = ' %#WinbarSeparator# '
local prefix, prefix_path = '', ''
local folder_icon = ''
-- If the window gets too narrow, shorten the path and drop the prefix.
if vim.api.nvim_win_get_width(0) < math.floor(vim.o.columns / 3) then
path = vim.fn.pathshorten(path)
else
-- For some special folders, add a prefix instead of the full path (making
-- sure to pick the longest prefix).
---@type table<string, string>
local special_dirs = {
DOTFILES = vim.env.XDG_CONFIG_HOME,
GITS = vim.env.HOME .. '/gits',
HOME = vim.env.HOME,
PROJECTS = vim.env.HOME .. '/projects',
}
for dir_name, dir_path in pairs(special_dirs) do
if vim.startswith(path, vim.fs.normalize(dir_path)) and #dir_path > #prefix_path then
prefix, prefix_path, folder_icon = dir_name, dir_path, icons.get('file',path)
end
end
if prefix ~= '' then
path = path:gsub('^' .. prefix_path, '')
prefix = string.format('%%#WinBarFile#%s %s%s', folder_icon, prefix, separator)
end
end
-- Remove leading slash.
path = path:gsub('^/', '')
vim.api.nvim_set_hl(0, "Winbar", { link = "Normal" })
vim.api.nvim_set_hl(0, "WinbarSeparator", { link = "Normal" })
vim.api.nvim_set_hl(0, "WinBarFile", { link = "Normal" })
return table.concat {
' ',
prefix,
table.concat(
vim.iter(vim.split(path, '/'))
:map(function(segment)
return string.format('%%#Winbar#%s', segment)
end)
:totable(),
separator
),
}
end
vim.api.nvim_create_autocmd('BufWinEnter', {
group = vim.api.nvim_create_augroup('afonso/winbar', { clear = true }),
desc = 'Attach winbar',
callback = function(args)
if
not vim.api.nvim_win_get_config(0).zindex -- Not a floating window
and vim.bo[args.buf].buftype == '' -- Normal buffer
and vim.api.nvim_buf_get_name(args.buf) ~= '' -- Has a file name
and not vim.wo[0].diff -- Not in diff mode
then
vim.wo.winbar = "%{%v:lua.require'winbar'.render()%}"
end
end,
})
return M

View file

@ -37,7 +37,6 @@ themes[gruvbox-original-hard-dark]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"hard\"
vim.g.gruvbox_material_foreground=\"original\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"dark\""
kitty_theme="Gruvbox Dark Hard"'
@ -53,7 +52,6 @@ themes[gruvbox-original-medium-light]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"medium\"
vim.g.gruvbox_material_foreground=\"original\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"light\""
kitty_theme="Gruvbox Light Medium"'
@ -69,7 +67,6 @@ themes[gruvbox-material-hard-dark]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"hard\"
vim.g.gruvbox_material_foreground=\"material\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"dark\""
kitty_theme="Gruvbox Material Dark Hard"'
@ -85,7 +82,6 @@ themes[gruvbox-material-medium-dark]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"medium\"
vim.g.gruvbox_material_foreground=\"material\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"dark\""
kitty_theme="Gruvbox Material Dark Medium"'
@ -101,7 +97,6 @@ themes[gruvbox-material-soft-dark]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"soft\"
vim.g.gruvbox_material_foreground=\"material\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"dark\""
kitty_theme="Gruvbox Material Dark Soft"'
@ -117,7 +112,6 @@ themes[gruvbox-material-hard-light]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"hard\"
vim.g.gruvbox_material_foreground=\"material\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"light\""
kitty_theme="Gruvbox Material Light Hard"'
@ -133,7 +127,6 @@ themes[gruvbox-material-medium-light]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"medium\"
vim.g.gruvbox_material_foreground=\"material\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"light\""
kitty_theme="Gruvbox Material Light Medium"'
@ -149,7 +142,6 @@ themes[gruvbox-material-soft-light]=\
vim.g.gruvbox_material_better_performance=1
vim.g.gruvbox_material_background=\"soft\"
vim.g.gruvbox_material_foreground=\"material\"
vim.g.gruvbox_material_transparent_background=2
vim.opt.background=\"light\""
kitty_theme="Gruvbox Material Light Soft"'