Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

allow disabling first level of scope indent #824

Open
LokiNaBoki opened this issue Jan 7, 2024 · 2 comments
Open

allow disabling first level of scope indent #824

LokiNaBoki opened this issue Jan 7, 2024 · 2 comments
Labels
enhancement New feature or request

Comments

@LokiNaBoki
Copy link

Problem

If you have the scope indents enabled, there is no option or hook to disable them in the first column.

As far as I can remember the show_first_indent_level option from V2 worked for both regular and scope indents. Now there is just hide_first_space_indent_level which hides only regular indents.

I made this hook to get rid of scope indents in the first column:

hooks.register(
    hooks.type.VIRTUAL_TEXT,
    function(_, _, _, virt_text)
        if virt_text[1] and virt_text[1][1] == '' then
            virt_text[1] = { ' ', { "@ibl.whitespace.char.1" } }
        end
                                                                 
        return virt_text
    end
)

but it feels really hacky. I have to hardcode the values: '┃' and { ' ', { "@ibl.whitespace.char.1" } }, instead of using indent.whitespace.INDENT and indent.whitespace.SPACE as in the built-in hook.

Expected behavior

The expected behavior is to have something like indent.whitespace enum, but for the scoped indents

@Saulimedes
Copy link

Saulimedes commented Aug 4, 2024

I stumbled upon the same issue and helped myself by defining a first highlight without colors.

local highlight = {
    "IblIndent", -- This will be invisible for the first level
    "RainbowRed",
    "RainbowYellow",
    "RainbowBlue",
    "RainbowOrange",
    "RainbowGreen",
    "RainbowViolet",
    "RainbowCyan",
}

local hooks = require "ibl.hooks"
-- create the highlight groups in the highlight setup hook, so they are reset
-- every time the colorscheme changes
hooks.register(hooks.type.HIGHLIGHT_SETUP, function()
    vim.api.nvim_set_hl(0, "IblIndent", { fg = "NONE" })
    vim.api.nvim_set_hl(0, "RainbowRed", { fg = "#E06C75" })
    vim.api.nvim_set_hl(0, "RainbowYellow", { fg = "#E5C07B" })
    vim.api.nvim_set_hl(0, "RainbowBlue", { fg = "#61AFEF" })
    vim.api.nvim_set_hl(0, "RainbowOrange", { fg = "#D19A66" })
    vim.api.nvim_set_hl(0, "RainbowGreen", { fg = "#98C379" })
    vim.api.nvim_set_hl(0, "RainbowViolet", { fg = "#C678DD" })
    vim.api.nvim_set_hl(0, "RainbowCyan", { fg = "#56B6C2" })
end)

But would have much more prefered some option like ident_level = 2.

@lukas-reineke
Copy link
Owner

The proper way to do this is probably to have a hook that can dynamically exclude a scope, here.

if
(scope_lang[lang][type] and not utils.tbl_contains(excluded_node_types, type))
or utils.tbl_contains(include_node_types, type)
or utils.tbl_contains(include_node_types, "*")
then

I'm open to add this if someone wants to make a PR.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants