diff options
| author | christianchiarulli <[email protected]> | 2021-04-15 00:17:48 -0400 | 
|---|---|---|
| committer | christianchiarulli <[email protected]> | 2021-04-15 00:17:48 -0400 | 
| commit | 2cd8c6a21cb6c9af91e631f565e31f5803cdaa7c (patch) | |
| tree | 7207301e310a278c0f91b4595ddc93fd98238093 /lua/lv-utils | |
| parent | 1853b4f2aa13b83ff542171060f92d3d4d961a68 (diff) | |
LunarVim
Diffstat (limited to 'lua/lv-utils')
| -rw-r--r-- | lua/lv-utils/init.lua | 190 | 
1 files changed, 190 insertions, 0 deletions
| diff --git a/lua/lv-utils/init.lua b/lua/lv-utils/init.lua new file mode 100644 index 00000000..c177cb09 --- /dev/null +++ b/lua/lv-utils/init.lua @@ -0,0 +1,190 @@ +local nv_utils = {} + +function nv_utils.define_augroups(definitions) -- {{{1 +    -- Create autocommand groups based on the passed definitions +    -- +    -- The key will be the name of the group, and each definition +    -- within the group should have: +    --    1. Trigger +    --    2. Pattern +    --    3. Text +    -- just like how they would normally be defined from Vim itself +    for group_name, definition in pairs(definitions) do +        vim.cmd('augroup ' .. group_name) +        vim.cmd('autocmd!') + +        for _, def in pairs(definition) do +            local command = table.concat(vim.tbl_flatten {'autocmd', def}, ' ') +            vim.cmd(command) +        end + +        vim.cmd('augroup END') +    end +end + +-- lsp + +function nv_utils.add_to_workspace_folder() +    vim.lsp.buf.add_workspace_folder() +end + +function nv_utils.clear_references() +    vim.lsp.buf.clear_references() +end + +function nv_utils.code_action() +    vim.lsp.buf.code_action() +end + +function nv_utils.declaration() +    vim.lsp.buf.declaration() +    vim.lsp.buf.clear_references() +end + +function nv_utils.definition() +    vim.lsp.buf.definition() +    vim.lsp.buf.clear_references() +end + +function nv_utils.document_highlight() +    vim.lsp.buf.document_highlight() +end + +function nv_utils.document_symbol() +    vim.lsp.buf.document_symbol() +end + +function nv_utils.formatting() +    vim.lsp.buf.formatting() +end + +function nv_utils.formatting_sync() +    vim.lsp.buf.formatting_sync() +end + +function nv_utils.hover() +    vim.lsp.buf.hover() +end + +function nv_utils.implementation() +    vim.lsp.buf.implementation() +end + +function nv_utils.incoming_calls() +    vim.lsp.buf.incoming_calls() +end + +function nv_utils.list_workspace_folders() +    vim.lsp.buf.list_workspace_folders() +end + +function nv_utils.outgoing_calls() +    vim.lsp.buf.outgoing_calls() +end + +function nv_utils.range_code_action() +    vim.lsp.buf.range_code_action() +end + +function nv_utils.range_formatting() +    vim.lsp.buf.range_formatting() +end + +function nv_utils.references() +    vim.lsp.buf.references() +    vim.lsp.buf.clear_references() +end + +function nv_utils.remove_workspace_folder() +    vim.lsp.buf.remove_workspace_folder() +end + +function nv_utils.rename() +    vim.lsp.buf.rename() +end + +function nv_utils.signature_help() +    vim.lsp.buf.signature_help() +end + +function nv_utils.type_definition() +    vim.lsp.buf.type_definition() +end + +function nv_utils.workspace_symbol() +    vim.lsp.buf.workspace_symbol() +end + +-- diagnostic + +function nv_utils.get_all() +    vim.lsp.diagnostic.get_all() +end + +function nv_utils.get_next() +    vim.lsp.diagnostic.get_next() +end + +function nv_utils.get_prev() +    vim.lsp.diagnostic.get_prev() +end + +function nv_utils.goto_next() +    vim.lsp.diagnostic.goto_next() +end + +function nv_utils.goto_prev() +    vim.lsp.diagnostic.goto_prev() +end + +function nv_utils.show_line_diagnostics() +    vim.lsp.diagnostic.show_line_diagnostics() +end + +-- git signs + +function nv_utils.next_hunk() +    require('gitsigns').next_hunk() +end + +function nv_utils.prev_hunk() +    require('gitsigns').prev_hunk() +end + +function nv_utils.stage_hunk() +    require('gitsigns').stage_hunk() +end + +function nv_utils.undo_stage_hunk() +    require('gitsigns').undo_stage_hunk() +end + +function nv_utils.reset_hunk() +    require('gitsigns').reset_hunk() +end + +function nv_utils.reset_buffer() +    require('gitsigns').reset_buffer() +end + +function nv_utils.preview_hunk() +    require('gitsigns').preview_hunk() +end + +function nv_utils.blame_line() +    require('gitsigns').blame_line() +end + +-- misc +function nv_utils.file_exists(name) +    local f = io.open(name, "r") +    if f ~= nil then +        io.close(f) +        return true +    else +        return false +    end +end + +return nv_utils + | 
