diff options
Diffstat (limited to 'lua')
| -rw-r--r-- | lua/core/log.lua | 43 | ||||
| -rw-r--r-- | lua/core/lualine/styles.lua | 5 | ||||
| -rw-r--r-- | lua/core/nvimtree.lua | 2 | ||||
| -rw-r--r-- | lua/core/terminal.lua | 4 | ||||
| -rw-r--r-- | lua/keymappings.lua | 4 | ||||
| -rw-r--r-- | lua/lsp/init.lua | 6 | ||||
| -rw-r--r-- | lua/lsp/null-ls/formatters.lua | 8 | ||||
| -rw-r--r-- | lua/lsp/null-ls/init.lua | 2 | ||||
| -rw-r--r-- | lua/lsp/null-ls/linters.lua | 8 | ||||
| -rw-r--r-- | lua/utils/init.lua | 10 | 
10 files changed, 57 insertions, 35 deletions
| diff --git a/lua/core/log.lua b/lua/core/log.lua index 5dd5622e..54620625 100644 --- a/lua/core/log.lua +++ b/lua/core/log.lua @@ -4,26 +4,57 @@ local Log = {}  ---@param opts these are passed verbatim to Plenary.log  ---@return log handle  function Log:new(opts) -  local status_ok, _ = pcall(require, "plenary.log") +  local status_ok, handle = pcall(require, "plenary.log")    if not status_ok then -    return nil +    vim.notify("Plenary.log is not available. Logging to console only", vim.log.levels.DEBUG)    end -  local obj = require("plenary.log").new(opts) +  self.__handle = handle +    local path = string.format("%s/%s.log", vim.api.nvim_call_function("stdpath", { "cache" }), opts.plugin) -  obj.get_path = function() +  self.get_path = function()      return path    end -  return obj +  setmetatable({}, Log) +  return self +end + +function Log:add_entry(msg, level) +  local status_ok, _ = pcall(require, "plenary.log") +  if not status_ok then +    return vim.notify(msg, vim.log.levels[level]) +  end +  -- plenary uses lower-case log levels +  return self.__handle[level:lower()](msg)  end  --- Creates or retrieves a log handle for the default logfile  --- based on Plenary.log  ---@return log handle -function Log:get_default() +function Log:new_default()    return Log:new { plugin = "lunarvim", level = lvim.log.level }  end +function Log:trace(msg) +  self:add_entry(msg, "TRACE") +end + +function Log:debug(msg) +  self:add_entry(msg, "DEBUG") +end + +function Log:info(msg) +  self:add_entry(msg, "INFO") +end + +function Log:warn(msg) +  self:add_entry(msg, "TRACE") +end + +function Log:error(msg) +  self:add_entry(msg, "TRACE") +end +  return Log diff --git a/lua/core/lualine/styles.lua b/lua/core/lualine/styles.lua index 876d7fa3..53b0691e 100644 --- a/lua/core/lualine/styles.lua +++ b/lua/core/lualine/styles.lua @@ -112,14 +112,13 @@ function M.get_style(style)    local style_keys = vim.tbl_keys(styles)    if not vim.tbl_contains(style_keys, style) then      local Log = require "core.log" -    local logger = Log:get_default() -    logger.error( +    Log:error(        "Invalid lualine style",        string.format('"%s"', style),        "options are: ",        string.format('"%s"', table.concat(style_keys, '", "'))      ) -    logger.info '"lvim" style is applied.' +    Log:info '"lvim" style is applied.'      style = "lvim"    end diff --git a/lua/core/nvimtree.lua b/lua/core/nvimtree.lua index bea1add4..b5a6cc8d 100644 --- a/lua/core/nvimtree.lua +++ b/lua/core/nvimtree.lua @@ -52,7 +52,7 @@ end  function M.setup()    local status_ok, nvim_tree_config = pcall(require, "nvim-tree.config")    if not status_ok then -    Log:get_default().error "Failed to load nvim-tree.config" +    Log:error "Failed to load nvim-tree.config"      return    end    local g = vim.g diff --git a/lua/core/terminal.lua b/lua/core/terminal.lua index 4fced26e..f9be8734 100644 --- a/lua/core/terminal.lua +++ b/lua/core/terminal.lua @@ -82,7 +82,7 @@ M._exec_toggle = function(exec)    local binary = M._split(exec)[1]    if vim.fn.executable(binary) ~= 1 then      local Log = require "core.log" -    Log:get_default().error("Unable to run executable " .. binary .. ". Please make sure it is installed properly.") +    Log:error("Unable to run executable " .. binary .. ". Please make sure it is installed properly.")      return    end    local Terminal = require("toggleterm.terminal").Terminal @@ -122,7 +122,7 @@ M.toggle_log_view = function(name)    local Terminal = require("toggleterm.terminal").Terminal    local log_view = Terminal:new(term_opts) -  -- require("core.log"):get_default().debug("term", vim.inspect(term_opts)) +  -- require("core.log"):debug("term", vim.inspect(term_opts))    log_view:toggle()  end diff --git a/lua/keymappings.lua b/lua/keymappings.lua index 7d75e06b..fa1af1c4 100644 --- a/lua/keymappings.lua +++ b/lua/keymappings.lua @@ -159,9 +159,7 @@ function M.config()      lvim.keys.normal_mode["<A-Down>"] = lvim.keys.normal_mode["<C-Down>"]      lvim.keys.normal_mode["<A-Left>"] = lvim.keys.normal_mode["<C-Left>"]      lvim.keys.normal_mode["<A-Right>"] = lvim.keys.normal_mode["<C-Right>"] -    if Log:get_default() then -      Log:get_default().info "Activated mac keymappings" -    end +    Log:info "Activated mac keymappings"    end  end diff --git a/lua/lsp/init.lua b/lua/lsp/init.lua index 631f142a..94fcf550 100644 --- a/lua/lsp/init.lua +++ b/lua/lsp/init.lua @@ -99,16 +99,14 @@ end  function M.common_on_init(client, bufnr)    if lvim.lsp.on_init_callback then      lvim.lsp.on_init_callback(client, bufnr) -    Log:get_default().info "Called lsp.on_init_callback" +    Log:info "Called lsp.on_init_callback"      return    end    local formatters = lvim.lang[vim.bo.filetype].formatters    if not vim.tbl_isempty(formatters) and formatters[1]["exe"] ~= nil and formatters[1].exe ~= "" then      client.resolved_capabilities.document_formatting = false -    Log:get_default().info( -      string.format("Overriding language server [%s] with format provider [%s]", client.name, formatters[1].exe) -    ) +    Log:info(string.format("Overriding language server [%s] with format provider [%s]", client.name, formatters[1].exe))    end  end diff --git a/lua/lsp/null-ls/formatters.lua b/lua/lsp/null-ls/formatters.lua index cae1fa7d..05e0ec62 100644 --- a/lua/lsp/null-ls/formatters.lua +++ b/lua/lsp/null-ls/formatters.lua @@ -3,7 +3,7 @@ local formatters_by_ft = {}  local null_ls = require "null-ls"  local services = require "lsp.null-ls.services" -local logger = require("core.log"):get_default() +local Log = require "core.log"  local function list_names(formatters, options)    options = options or {} @@ -45,15 +45,15 @@ function M.list_configured(formatter_configs)      local formatter = null_ls.builtins.formatting[fmt_config.exe]      if not formatter then -      logger.error("Not a valid formatter:", fmt_config.exe) +      Log:error("Not a valid formatter:", fmt_config.exe)        errors[fmt_config.exe] = {} -- Add data here when necessary      else        local formatter_cmd = services.find_command(formatter._opts.command)        if not formatter_cmd then -        logger.warn("Not found:", formatter._opts.command) +        Log:warn("Not found:", formatter._opts.command)          errors[fmt_config.exe] = {} -- Add data here when necessary        else -        logger.info("Using formatter:", formatter_cmd) +        Log:info("Using formatter:", formatter_cmd)          formatters[fmt_config.exe] = formatter.with { command = formatter_cmd, extra_args = fmt_config.args }        end      end diff --git a/lua/lsp/null-ls/init.lua b/lua/lsp/null-ls/init.lua index 8691982e..ce4c07d9 100644 --- a/lua/lsp/null-ls/init.lua +++ b/lua/lsp/null-ls/init.lua @@ -30,7 +30,7 @@ function M.setup(filetype, options)    local ok, _ = pcall(require, "null-ls")    if not ok then -    require("core.log"):get_default().error "Missing null-ls dependency" +    require("core.log"):error "Missing null-ls dependency"      return    end diff --git a/lua/lsp/null-ls/linters.lua b/lua/lsp/null-ls/linters.lua index b449a4f2..70c59974 100644 --- a/lua/lsp/null-ls/linters.lua +++ b/lua/lsp/null-ls/linters.lua @@ -3,7 +3,7 @@ local linters_by_ft = {}  local null_ls = require "null-ls"  local services = require "lsp.null-ls.services" -local logger = require("core.log"):get_default() +local Log = require "core.log"  local function list_names(linters, options)    options = options or {} @@ -45,15 +45,15 @@ function M.list_configured(linter_configs)      local linter = null_ls.builtins.diagnostics[lnt_config.exe]      if not linter then -      logger.error("Not a valid linter:", lnt_config.exe) +      Log:error("Not a valid linter:", lnt_config.exe)        errors[lnt_config.exe] = {} -- Add data here when necessary      else        local linter_cmd = services.find_command(linter._opts.command)        if not linter_cmd then -        logger.warn("Not found:", linter._opts.command) +        Log:warn("Not found:", linter._opts.command)          errors[lnt_config.exe] = {} -- Add data here when necessary        else -        logger.info("Using linter:", linter_cmd) +        Log:info("Using linter:", linter_cmd)          linters[lnt_config.exe] = linter.with { command = linter_cmd, extra_args = lnt_config.args }        end      end diff --git a/lua/utils/init.lua b/lua/utils/init.lua index 80a2dbe6..322a961f 100644 --- a/lua/utils/init.lua +++ b/lua/utils/init.lua @@ -70,9 +70,7 @@ function utils.toggle_autoformat()          },        },      } -    if Log:get_default() then -      Log:get_default().info "Format on save active" -    end +    Log:info "Format on save active"    end    if not lvim.format_on_save then @@ -81,9 +79,7 @@ function utils.toggle_autoformat()          :autocmd! autoformat        endif      ]] -    if Log:get_default() then -      Log:get_default().info "Format on save off" -    end +    Log:info "Format on save off"    end  end @@ -104,7 +100,7 @@ function utils.reload_lv_config()    -- vim.cmd ":PackerClean"    local null_ls = require "lsp.null-ls"    null_ls.setup(vim.bo.filetype, { force_reload = true }) -  Log:get_default().info "Reloaded configuration" +  Log:info "Reloaded configuration"  end  function utils.unrequire(m) | 
